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1 . INTRODUCTION 

1.1 DESCRIPTION 

The TMS99000 series is a third generation family of single-chip 16-bit micrroprocessors and advanced 
peripherals, using N-channel silicon-gate SMOS technology. The TMS99000 family of processors offers un- 
precedented speed and a powerful instruction set that is an opcode-compatible enrichment of the TMS9900 and 
TMS9995 instruction set. These processors build on the unique memory-to-memory architecture that was 
pioneered at Texas Instruments and feature multiple register files, resident in memory, to permit faster response to 
interrupts and increased programming flexibility. 

The TMS99000 family includes two microprocessors, the TMS99105A and the TMS991 10A, which are iden- 
tical except for specialized programmations of the on-chip Macrostore memory. The ROM macrostore in the 
TMS991 1 0A microprocessor contains floating point instructions as part of the machine language instruction set. 
The TMS99105A microprocessor contains RAM macrostore while the TMS99110A contains both RAM and 
ROM macrostore. 

Texas Instruments manufactures a complete set of MOS and TTL integrated circuits to provide memory and logic 
functions for the TMS99000 system. The system is fully supported by software and a complete prototyping 
system. 

All references in this document, unless explicitly indicated, refer to all members of the TMS99000 family of 
microprocessors. 

1.2 KEY FEATURES 

• 1 6-bit instruction word 

• Memory-to-memory architecture 

• Instantaneous access to 256K bytes of memory 

• 84-instruction superset of TMS9900 instruction set 

- SIGNED multiply and divide 

- Long-word 132-bit) shift, add, subtract 

- Load status register, load workspace pointer 

- Stack support - branch and push link, branch indirect 

- Multiprocessor support - test, test and clear, test and set 

Privileged mode 

Macrostore* emulation of user-defined instructions 

Status signals to identify processor activity 

Interrupt acknowledge signal 

Arithmetic fault interrupt 

Illegal instruction interrupt 

1 6 prioritized hardware interrupts 

1 6 software interrupts (XOPS) 

Programmed I/O 

DMA compatible 

Bit - , byte - and word-addressable I/O 

Multiprocessor system interlock signal (hardware support for indivisible operations on semaphores) 

Attached processor interface 

N-channel silicon-gate SMOS technology 

167 nsec machine cycle time 

On-chip clock generator and oscillator 



'Macrostore is a trademark of Texas Instruments Incorporated 



• 40-pin package 

• Single + 5 volt supply 

2. ARCHITECTURE 

2.1 MEMORY ALLOCATION 

The memory word of the processor is 1 6 bits long as shown in Figure 1 . Words are assigned even-numbered ad- 
dresses in memory. The contents of each memory word can also be treated as two bytes of eight bits each. The in- 
struction set supports both word and byte operations. A 1 6-bit address is explicitly manipulated by all memory ad- 
dressing modes, but only the 1 5-bit word address is provided to the memory system. This allows direct addressing 
of 64K bytes of memory space, referred to as the logical address space. The instantaneous address reach of the 
processor may be increased to 256K bytes using the techniques described in Section 3.2.3. 
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FIGURE 1 - WORD AND BYTE FORMATS 



Byte instructions may access either byte as necessary. Byte instructions involving workspace register data 
operate on the most-significant byte (even address in Figure 1 > of the workspace register, and leave the least- 
significant byte (odd address) unchanged. The two bytes in a register can be swapped using the SWPB instruc- 
tion. Additionally, since the workspace resides in memory, the least-significant byte of a register may be address- 
ed, if desired, using any of the general memory addressing modes. 

The processor memory map (Figure 2) shows the locations in the memory address space for the interrupt and XOP 
trap vectors, and the non-maskable interrupt (NMI). All remaining memory space is available for programs, data, 
and workspaces. 
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FIGURE 2 - MAP OF MAIN MEMORY ADDRESS SPACE 



2.2 TMS99000 BLOCK DIAGRAM AND FLOW CHART 

The block diagram of the processor is shown in Figure 3. A flowchart, representative of the processor functional 
operation, is shown in Figure 4, 
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FIGURE 3 - BLOCK DIAGRAM OF TMS99000 



RESET 



EXTERNAL INTERRUPT 
LEVELS 1-15 



YES 



<? 




VECTOR @0000(1 6) 
MASK^-0000 



»| VECTOR @FFFC( 161 
MASK^>0000 



VECTOR @>0008( 16) 
MASK^-0001 



VECTOR @>0000( 16) 
MASK ^-0000 



VECTOR @4 (ICO-3) 

MASK^- 
ACTIVE LEVEL - 1 



CLEAR ST REGISTER 
CLEAR EIST FLAGS 




YES 



YES 



READ NEW WP 
AND PC 



SAVE OLD WP 
IN WR13 



SAVE OLD PC 
INWR14 



SAVE OLD ST 
INWR15 



-'clear ST7-1 1 

AND LOAD NEW 

INTERRUPT 

MASK INTO 

ST12-ST15 




^ 



FIGURE 4 - TMS99000 FLOWCHART 
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FIGURE 4 - TMS99000 FLOWCHART (CONT'D) 
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FIGURE 4 - TMS99000 FLOWCHART (CON'D) 
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FIGURE 4 - TMS99000 FLOWCHART (CONCLUDED) 



2.3 ARITHMETIC LOGIC UNIT 

The arithmetic logic unit (ALU) performs all arithmetic and logical operations required during instruction execution. 
These operations include addition, subtraction, AND, OR, exclusive-OR and complement. A separate comparison 
circuit within the chip performs the logical and arrthmetic comparisions needed to control bits 0, 1 and 2 (Figure 5) 
of the status register. Byte operations are performed in the most-significant half of the ALU. The least-significant 
half of the result in byte operations is left unchanged. This conveniently permits the status circuitry used for word 
operations to be used for byte operations as well. 

2.4 INTERNAL REGISTERS 

The following three internal registers are accessible to the programmer: 

• Program Counter (PC) 

• Status Register (ST) 

• Workspace Pointer (WP) 

Other internal registers that perform instruction acquisition and execution are inaccessible to the programmer. 

2.4.1 Program Counter 

The program counter (PC) is a 1 5-bit hardware register that contains the memory address (or external Macrostore 
address; see Section 7) of the instruction word following the currently executing instruction. 

Conceptually, the PC is a 1 6-bit register that functions as a count-by-two counter with the least-significant bit 
(LSB) hardwired to 0. Since instructions are constrained to word boundaries, the processor reads the instruction 
word from the location pointed to by the PC, and increments the contents of the PC by two in preparation for the 
next instruction fetch. A program branch is performed by replacing the contents of the PC with the address of an 
instruction word located in memory or Macrostore. All jump, branch and context-switching instructions alter the 
PC in this manner. 

2.4.2 Status Register 

The status register (ST) is a fully-implemented 16-bit internal register whose contents signify the results of 
arithmetic and logical comparisons, indicate program status conditions, and supply the arithmetic fault interrupt 
enable and the interrupt mask to the interrupt priority circuits. Each bit position in the register represents a par- 
ticular processor function or condition. Figure 5 illustrates the bit position assignments. Certain instructions, when 
executed, use the status register to check for a prerequisite condition; others affect the values of the bits in the 
register; still others load the entire status register with a new value. This last case occurs when an LST, RTWP or 
XOP instruction is executed. Other conditions causing a new status to be loaded are ( 1 ) an interrupt, and (2) return 
of system control from an attached processor (Section 8) to the host system. After the new status has been load- 
ed, an ST bus status code is output along with bits 7 to 11 of the updated status register. 

The effect of each individual instruction on the contents of the status register is described in Section 1 0.5. The in- 
dividual status register bits are identified in Section 1 0.4 along with the conditions affecting each bit. 

2.4.3 Woricspace 

A workspace is a block of 1 6 contiguous words in memory that contains frequently-accessed data and addresses. 
The location of the workspace is defined by the workspace pointer register, internal to the processor, which con- 
tains the address of the first word in the workspace. 

Each word in the workspace is treated as an individual 1 6-bit general-purpose register. Workspace registers (WRs) 
contain data and addresses, and function as operand registers, accumulators, address registers and index 
registers. During interrupts and certain instructions, however, particular WRs are assigned the special roles 
described in Table 1 . As indicated in the workspace map in Figure 6, alM 6 WRs manipulate data and addresses, 
-but only WRs 1 through 1 5 can be used as index registers. 
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TABLE 1 - DEDICATED WORKSPACE REGISTERS 



REGISTER 






NUMBER 


CONTENTS 


USED DURING 





Shift count (optional) 


Shift instructions (SLA, SPA, SRC, and SRL) 




Multiplicand and MSW of result 


Signed multiply 




MSW of dividend and quotient 


Signed divide 




MSW of floating point accumulator 


Floating point operations 


1 


LSW of result 


Signed multiply 




LSW of dividend and remainder 


Signed divide 


11 


Return address 


Branch and link instruction (BL) 




Effective address 


Extended operation (XOP) 


12 


CRU base address 


CRU instructions (SBC, SBZ, IB, LDCR, and 
STCR) 


13 


Saved WP register 


Context switching (BLWP, RTWP, XOP, 
recognized interrupt, NMI, and RESET), ex- 
ternal process 


14 


Saved PC register 


Context switching (BLWP, RTWP, XOP 
recognized interrupt, NMI, and RESET), ex- 
ternal process 


15 


Saved ST register 


Context switching (BLWP, RTWP, XOP, 
recognized interrupt, NMI, and RESET), ex- 
ternal process 



WORKSPACE POINTER REGISTER 



WORKSPACE 
ADDRESS REGISTER 

IN MEMORY NUMBER 



WP 



THE MICROPROCESSOR ADDS THE CON- 
TENTS OF THE WP TO TWO TIMES THE 
WORKSPACE REGISTER NUMBER TO DERIVE 
THE ADDRESS IN MEMORY OF THE REGISTER. 
WORKSPACE REGISTERS ARE ALWAYS 
LOCATED AT EVEN ADDRESSES SINCE THEY 
FALL ON WORD BOUNDARIES. 



(WP) + 00 



(WP)-i-02 



(WP) + 04 



(WP) + 06 ♦- 



(WP) + 08 ♦^ 



(WP) + OA 



tWPKOC 



|WP) + OE 



(WP)-HO 



{WP)+12 ♦- 



{WP)+14 ♦■ 



(WP)+16 



|WP)+18 



(WP)-l-IA 



(WP)-HC ♦■ 



(WP)-l-IE 



WRO 



WR1 



WR2 



WR3 



WR4 



WR5 



WR6 



WR7 



WR8 



WR9 



WR10 



WR11 



WR12 



WR13 



WR14 



WR15 



FIGURE 7 - WORKSPACE POINTER AND REGISTERS 



12 



The location of the workspace in memory is defined by a hardware register, internal to the processor, called the 
workspace pointer (WP). The WP contains the address of the first workspace register (WRO). Conceptually, the 
WP is a 1 6-bit register with the LSB hardwired to 0. As indicated in Figure 7, the memory address of WRn, 
n = 0,1 15, is calculated as (WP) + 2n.* 

2=4=4 Context Switching 

The processor's memory-resident workspace is a particularly valuable feature in applications that require frequent 
context switches. A context switch is a change from one program execution environment to another such as 
takes place during a subroutine call or an interrupt. Since the workspace registers already reside in memory, the 
processor performs a context switch simply by saving its three internal registers, the WP, PC and ST, in memory 
and fetching the new WP and PC from memory. 

The processor realizes a similar time savings in returning from an interrupt or subroutine. The original context is 
restored by simply replacing the contents of the WP, PC and ST with the values saved in memory. 

The instructions that result in a context switch include BLWP (branch and load workspace pointer), RTWP (return 
from subroutine or interrupt) and XOP (extended operation). A device interrupt, arithmetic fault interrupt, privileg- 
ed opcode violation, illegal instruction error, a RESET or an NMI (non-maskable interrupt) also causes a context 
switch by forcing the processor to trap to a service routine. 

2.4.5 Access of PC, ST. and WP 

System control can be transferred from the processor to an external device such as an attached processor or 
maintenance panel. During the transfer of control, the processor writes the contents of its WP, PC and ST to 
memory where they can be accessed and modified by the external device. Upon return of control to the processor, 
the WP, PC and ST are updated with the modified values from memory. The details are presented in Section 8. 

2.5 MACROSTORE 

The TMS99000 addresses a 64K byte memory address space, which is logically distinct from the main memory 
address space. This memory space, which is called Macrostore, is logically differentiated from the main memory 
space through a bus status code output by the processor. 

The TMS99000 has reserved the first 4K byte addresses for on-chip Macrostore memory. Of this 4K byte space, 
there are 1 K bytes of ROM and 32 bytes of RAM implemented on the initial versions of the TMS99000. The 
TMS991 05 does not utilize its on-chip ROM; however it does provide the 32 bytes of RAM eliminating the exter- 
nal RAM requirement in many cases where external Macrostore memory is provided. Other versions of the 
TMS99000 family provide preprogrammed functions in the on-chip Macrostore ROM (e.g. TMS991 10 floating 
point). All members of the TMS99000 family can address external Macrostore memory for prototyping and ap- 
plications requiring more than the 1 K bytes of on-chip ROM. 

Macrostore memory space implements added functions or instructions through emulation routines written in stan- 
dard machine code. The Macrostore address space is entered through the attempted execution of a subset of the 
unused opcodes called macroinstructions. When attempted execution of the macroinstruction takes place, the 
processor traps to a specified location within the Macrostore. It is the Macrostore-resident software's responsibili- 
ty to decode and perform the emulation of the function or instruction. A Macrostore memory map is shown in 
Figure 8. Section 7 describes the interface and use of the Macrostore memory space. 

'Enclosing WP in parenthesis means that the contents of WP are being refen-ed to. 
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AREA DEFINITION 



MEMORY 
ADDRESS 



MEMORY CONTENTS 



INTERNAL MACROSTORE 

ADDRESSES (ALL BUT 

RAM MAY BE MAPPED 

EXTERNALLY) 



EXTERNAL MACROSTORE 
ADDRESS 



< 



> 



>001E 
>0020 



>07FE 
>0800 



>0812 
>0814 



>OBDE 
>OBEO 



>OFFE 
>1000 



< 



y//////////// 

// / FUTURE EXPANSION / / / 

V//////////A 



\ 



>FFFE 



32 BYTES ON-CHIP RAM 



ENTRY TABLE 



1K BYTES ON-CHIP ROM 




/ ^ USER'S ROM AND RAM / ^ 



FIGURE 8 - MACROSTORE MEMORY ADDRESS SPACE 



3. 
3.1 



TMS99000 MEMORY INTERFACE 



DEFINITION 



The processor pin functions are de scribe d in Section 9. Several of tiie pins have dual or multiple functions deter- 
mined by the state of the ALATCH, MEM, and bus status code (BST1 -BST3) outputs. Processor operations involv- 
ing the transfer of data utilize the time-multiplexed address and data lines. These lines, along with the correspon- 
ding control signals, comprise the local bus interface of the processor. The local bus interface is used to perform 
memory, DMA, input/output, external Macrostore, and attached processor operations. 

The term, bus cycle, describes the sequence of handshake operations necessary to complete the transfer of one 
datum over the local bus. The beg inning of each bus cycle is marked by a positive ALATCH pulse, during which an 
address is output on the bus, and MEM and the bus status code become valid. Each particular type of bus cycle is 
indicated by its own unique bus status code (Table 2). A read or write operation is indicated early in the cycle by 
the RA/V output. The R/W output acts as an early predictor of whether the AD buffers will tristate when in the data 
bus mode (after the falling edge of ALATCH). The R/W output is different from traditional R/W indicators in that 
the R/W output provides direction indication for both memory and non-memory cycles. During memory write 
operations, R/W remains at a low level throughout the memory cycle, During memory read operations, R/W re- 
mains at a high level throughout the memory cycle. The R/W output may be used to enable the direction on various 
databus buffers. The R/W output also provides an early indication of the RD output such that when_R/Wis high at 
the beginning of the cycle, RD will be taken low by the processor after ALATCH goes low. If R/W is low at the 
beginning of the cycle, the RD output will remain high after ALATCH goes lov/. Following the falling edge of the 
ALATCH pulse, the bus is used either to perform a write operation or is forcw to the high-impedance state for a 
read operation. The bus status, R/W, and MEM outputs remain stable thro'/ghout the duration of the bus cycle, 
and either the WE/IOCLK or RD output may be pulsed low to perform a write or read operation. 
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TABLE 2 -BUS STATUS CODES 



MEM- 


1 


BST 
2 3 


NAME 


DESCRIPTION OF BUS ACTIVITY 


L 


L 


L 


L 


SOPL 


Source operand transfer with MPILCK asserted. 




L 


L 


L 


H 


SOP 


Source operand transfer. MPILCK is inactive. 




L 


L 


H 


L 


lOP 


Immediate data or second word of two-word instruction, or symbolic address. 




L 


L 


H 


H 


lAQ* 


Instruction acquisition. First word of instruction is fetched from memory. 




L 


H 


L 


L 


OOP 


Destination operand transfer. 






H 


L 


H 


INTA 


Interrupt acknowledge. Active during the WP and PC fetch for an interrupt or XOP. 




L 


H 


H 


L 


WS 


Workspace transfer (or multi-word transfer beginning with WR1 5, and Ts=0). 




L 


H 


H 


H 


GM 


General memory transfer. 




H 


L 


L 


L 


AUMSL 


Internal arithmetic-logical unit operation or macrostore access with MPILCK asserted. 




H 
H 


L 

L 


L 
H 


H 
L 


AUMS 
RESET 


internal arithmetic-logical unit operation or macrostore access. MPILCK is inactive. 




Reset. The RESET input is pulled low. 


H 


L 


H 


H 


10 


I/O transfer 




H 


H 


L 


L 


WP 


Workspace pointer update due to BLWP, RTWP, LWP, XOP, APP entry, APP exit or intermpt. 
new workspace pointer is on the address bus. 


The 


H 


H 


L 


H 


ST 


Status register update due to LST, RTWP, XOP, APP exit or interrupt. Bits 7-11 of the new status 
are on the address bus. This occurs prior to the fetch of the next instruction. 


H 


H 


H 


L 


MID 


Macroinstruction detected. APP is sampled when READY is high. 




H 


H 


H 


H 


HOLDA 


Hold acknowledge. 





'Due to opcode prefetch, lAQ for the next instruction may t>e output before the result of the current instruction is stored. 



During bus cycles dedicated to internal functions, the RD and WE/IOCLK outputs remain high and R/W goes low: 
no transfer of data takes place, although a bus status code is output. During these operations, the activity of the 
ALATCH and address-data lines is as described in the previous paragraph. 

For convenience, reference will occasionally be made to the "address bus" and "data bus" as if they were 
separate lines. The reader should remember that address and data are, in fact, multiplexed over the same physical 
lines. 

The basic time unit of the local bus interface is the machine state, which has a duration of one CLKOUT period. A 
bus cycle minimally requires one machine state to complete but may be extended by some integral number of ad- 
ditional machine states. 

Bus cycles can be extended by the READY input signal. READY is manipulated by external logic to permit the pro- 
cessor to work with slow memory or I/O devices. The additional machine states generated by the READY signal 
are called wait states. It should be noted that wait states may be generated even during internal ALU cycles as in- 
dicated by the bus status codes. 

Three types of bus cycle are distinguished: memory, I/ O and intern al. During a memory or I/O cycle, a data transfer 
takes place on the local bus accompanied by either the WE/IOCLK output signal. During all cycles R/W also is out- 
put to give an early indi cation of re ad/write at the start of the cycle and continues to be active until the end of the 
bus cycle. Either RD or WE/IOCLK is active during an internal cycle involving an access of external macrostore. 
During internal machine cycles , which are not Macrostore cycles (as defined by the bus status codes AUMSL and 
AUMS), the RD and WE/IOCLK outputs remain inactive high. Memory and non-1/0 cycles have a minimum duration 
of one machine state, and a I/O cycle has a minimum duration of two machine states. A memory, I/O or internal cy- 
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cle can be extended by an arbitrary number of wait states by pulling the READY input low. Note that because in- 
ternal cycles can be wait-stated, care must be exercised in the design of external READY control logic to avoid 



w«iii-siaiiiiy iiiiBiiiai uyuies iiiai aits iiui iviauiusiuic uyuies. 



3.2 MEMORY INTERFACE 

The signals used in the interface to system memory are shown in Figure 9. 



C 



TMS99000 
CPU 



MEM 



R/W 



ADDRESS/DATA (0-15) 



^ 



ALATCH 



WE/IOCLK 



RD 



READY 



HOLD 



BST(1-3) 



^ 



FIGURE 9 - MEMORY INTERFACE 



MEMORY 
SYSTEM 



3.2.1 Memory Write Operattons 

The timing for a memory write cy cle is s hown in Figure 10. At the beginnin g of t he cycle, the process or ass erts 
ALATCH, outputs the address and PSEL on the address-data lines, and pulls MEM low. Concurrent with MEM go- 
ing low, RAW goes low to give an early indication of a memory write c ycle. The CPU then pulls ALATCH low, out- 
puts the data word on the address-data lines, and asserts WE/IOCLK. The cycle may be extended by wait states 
using the READY signal, as described in Section 3.2.5. 



(3) 



(3) 



(3) 



A/DBUS 



PSEL. BST1 BST3 



R/W 



IXjOC 




± 



J 



(2) 



y:^2^ 



Z2l 



=4 



Rn L 






(2) 



VALID CODE 



MEMORY 

WRITE 
NO WAITS 



NOTES: 

(1 ) Address and PSEL are valid. 

(2) Memory write data valid. 

(3) READY is sampled at this time. 



MEMORY WRITE 
' ONE WAIT-STATE 



FIGURE 10 - MEMORY WRITE CYCLE OPERATION 
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3.2.2 Memory Read Operations 

The timing for a memory read cycl e is s hown in Figure 1 1 . At the beginnin g of th e cycle, the processor asserts 
ALATCH, outputs the address and PSEL on the address-data lines, and pulls MEM low. The R/W output goes to a 
high level to indicate that the cycle is to be a memory read operation. The processor then pulls ALATCH low, 
forces the address-data lines into the high-impedance state, and pulls RD low to enable the read data from memory 
onto the address-data lines. The cycle may be extended by wait states using the READY signal, as described in 
Section 3.2.5. 



CLKOUT 
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I (3) I (3) I 



ALATCH 
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_l I 
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J—^ 



VALID CODE 



I 
I 



MEM 



R/W 



RD 



\. 



y 



WE/IOCLK 



MEMORY 

READ 
NO WAITS 



I 
\ 



f 



MEMORY READ 
ONE WAIT STATE 



NOTES: 

(1 ) Address and PSEL are valid. 

(2) Bus is in input mode (drivers are tristated). 

(3) Memory read data must be valid at indicated CLKOUT edge. 

(4) READY is sampled at this time. 



FIGURE 1 1 - MEMORY READ CYCLE OPERATION 

3.2.3 Extended Memory Addressing 

Several techniques are available for extending the address reach of the processor. These techniques use the PSEL 
and bus status codes (BST1-BST3) to provide for extended address reach by defining additional 64K byte pages 
of memory based on information output by the processor during every memory cycle. 



3. 2. 3. 1 Memory Paging 



Status bit 8 of the status register is inverted and multiplexed on the PSEL/DO/OUT pin. PSEL may be used as a 
1 7th address bit to select between two pages of 64K bytes for a total address reach of 1 28K bytes of physical 
memory. 



The PSEL signal outpu t occu rs concurrently with the memory address when ALATCH is active high. The following 
instructions force the PSEL output to the high state regardless of the value of STB of the status register: 

• RTWP return from interrupt 

• XOP extended operations (software trap) 

• All interrupts 

• All I/O instructions 
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In addition, tiie LST (load status) instruction can modify the PSEL output if the state of ST8 of the st atus r egister is 
changed by the instruction. The long distance source/destination instructions (LDS, LDD) cause the PSEL to be in- 
verted from the previous state during the source or destination access by the instruction following LDS or LDD, 
respectively, (see Section B.3). 

3. 2. 3. 2 Functional Segmentation 

In addition to paging capability using the PSEL output, memory may be segmented functionally into an instruction 
segment and a data segment. Referring to Table 2, the bus status codes lOP and lAQ may be decoded to create a 
segment-select line for differentiating between references to the instruction segment and the data segment. Note 
that BST3 is a "don't care" during the decode operation. The decoding necessary to distinguish between 
references to data and instruction segments is shown in Figure 1 2. Figure 1 3 illustrates the hierarchy of a 256K 
byte physical memory system utilizing the memory paging and functional segmentation techniques. 



BST1 



BST2 



Q 



INSTRUCTION/DATA 



MEM 



FIGURE 12 - FUNCTIONAL SEGMENTATION LOGIC 
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(64K) 
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(64K) 



PAGE 1 
(64K) 



PAGEO 
(64K) 



PAGE 1 
(64K) 



— V — 

256K BYTES 



FIGURE 13 - TMS99000 EXTENDED ADDRESSING 



5. 2. 3. 3 Memory Mapping Techniques 

The TMS99000 may utilize the TIM9961 memory mapper (SN74LS61 0) device to extend the address reach of 
the processor to 1 6 megabytes. The TIM9961 device contains 1 6 1 2-bit map registers, which are selected by 
the TMS99000's four most-significant address lines. These 1 2 bits are output from the TIM996 1 and appended 
to the address bus as the most-significant address lines. Thus, mapped pages may reside on any 4K-byte address 
boundary. 
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The PSEL output may be used to enable/disable the operation of the memory mapper. If PSEL is connected to the 
MM pin of the mapper circuit, the mapping of the internal map registers occurs only when PSEL is low. When PSEL 
is inactive high, the four address bits present on the register-select inputs are passed through to the outputs un- 
changed. This allows for correct operation when interrupt or XOP (extended operations) vectors are fetched from 
predefined locations. 

The TMS991 10 contains two instructions which are designed to facilitate operation with a TIM9961 memory 
mapper. They are Long Distance Source (LDS) and Long Distance Destination (LDD). These instructions are 
described in more detail in the TMS991 10 supplement (Appendix B). The LDS and LDD instructions invert the 
PSEL output when performing source and destination operand fetches of the following instruction. This allows an 
instruction to reach operands outside the boundaries of the current page. Figure 14 illustrates the interface 
between a TMS99000 and the TIM99610 memory mapper. 




ADDRESS BUS 



PSEL MAP ENABLE 




DATA BUS 



TIM99610 
MEMORY 
MAPPER 



J\ 




> 



FIGURE 14 - TMS99105A OR TMS991 10A TO TIM99610 MEIVIORY MAPPER INTERFACE 



3.2.4 Direct Memory Access 

The processor provides the signals necessary to allow DMA devices to directly transfer information to and from 
the system memory. To gain co ntrol o f the local bus interface, the DMA device sends a hold request to the pro- 
cessor by pulling the processor HOLD input low. 



The timing for the hold cycle is presented in Figure 1 5. Assume that HOLD is pulled low during a memory write cy- 
cle, as ind icated in the example of Figure 1 5. As soon as the ongoing cycle is complete, the processor responds to 
the HOLD signal by outputting a HOLDA bus status code (MEM, R/W and BST1-BST3 are all driven high); this 
signals its impending surrender of the local bus to the DMA device. The bus status code is held only for a quarter 
state, long enough to be latched externally on the falling edge of ALATCH. As soon as ALATCH has made its high- 
to-low transition, the following output signals are forced to the high-impedance state: MEM, R/W, BST1-BST3, 
WE/IOCLK, RD and the address-data lines. At the beginning of the next machine state, the ALATCH signal is 
driven high for a quarter state, after which it also is forced to high impedance. These lines remain in the high im- 
pedance state for the duration of the hold cycle. The CLKOUT output line, on the other hand, remains active 
through the hold cycle. The DMA device takes control of the local bus and performs its transfer or transfers of data 
to or from main memory. When the DMA device has completed its transfers, it deactivates the HOLD signal. The 
processor responds by removing the HOLDA bus status code, and leaves the hold state to resume processing. 
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CLKOUT 
A/D BUS 
ALATCH 
BST(1-3) 
MEM 
R/W 

RD 



WE/IOCLK 



HOLD 




PRIOR I 
I STATE I 
I (WRITE I 
I SHOWN) I 



HOLD CYCLE 
MAY BE ANY NUMBER OF CLOCKS 



NEXT 

STATE 

(READ SHOWN) 



NOTES: 



(1 ) CLKOUT edge at which HOLD is sampled. 

(2) Tristate all outputs except ALATCH as follows: 

• BST( 1-3) and R/W areJHrst driven high to indicate hold acknowledge, and then tristated. 

• MEM, RD, WE, and R/W are first driven high, and then tristated. 

• The data bus is tristated as is. 

(3) ALATCH is first driven high, and then tristated. 

(4) All outputs become active again. 



RGURE 15 - MEMORY CYCLE - DMA HOLD OPERATION 



The processor samples HOLD at the falling edge of each CLKOUT pulse. Sampling of HOLD occurs even while the 
MPILCK (multiprocessor interlock) bus status code is being output (Section 3.4.4) in order to reduce worst-case 
DMA latency. 



If HOLD is asserted at the beginning of a reset operation, the processor requests no me mor y cycles until HOLD is 
removed. This permits automatic DMA loading of memory after power up. When HOLD and RESET are pulled low 
at the same clock edge, the RESET bus status code will be output prior to the HOLDA bus status code and for as 
long as RESET remains active low. 

If the READY input signal is low when HOLD is released, the hold cycle is extended with wait states until READY is 
allowed to go high. 

3.2.5 Memory Wait-State Generation 

The READY input is held low to extend memory, I/O, and internal bus cycles by an arbitrary number of wait states. 
Wait states continue to be generated until READY is released (i.e., allowed to go high). Wait state generation for 
I/O cycles is presented in Section 5. 

READY is low during the first machine state of a memory cycle, however, the cycle is extended by one wait-state. 
If READY continues to be held low, the memory cycle is extended by additional wait-states until READY goes high. 
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External Macrostore accesses are treated as a special type of internal cycle. These cycles can be extended with 
wait-states by pulling READY low (see Section 7). 

The timing for wait state generation during memory cycles is shown in Figure 1 6. This same technique may be 
used for machine cycles which are neither memory nor I/O cycles (i.e. internal cycles). Thus care must be taken 
when designing circuitry controlling the READY input. As indicated in the figure, READY is sampled at the falling 
edge of CLKOUT. 



(1) 

CLKOUT y\y\y 

i 



ALATCH 




/\ r\ /^\_ r\ r^ 



I 




READY maa/mi ss^zl^t^zs sxssssErysa 



(3) I I ! II 



NO WAIT STATE ONE WAIT STATE ONE WAIT STATE 

GENERATED BY READY GENERATED BY WAITGEN 



NOTES: 

(1 ) First sample time of READY during bus cycle. 

(2) Second sample time of READY during bus cycle. Additional wait states are generated by keeping READY low at this and subse- 
quent sample times. 

(3) XXXXXX denotes don't care. 

(4) READY is sampled on non-memory as well as memory cycles. 



FIGURE 16 - WArr-STATE GENERATION FOR MEMORY BUS CYCLES 



3.3 PROCESSOR INTERNAL CYCLE INDICATION 

The bus status code output by the processor distinguishes internal cycles from memory and I/O cycles. Referring 
to Table 2, the AUMSL, AUMS, RESET, WP, ST, MID, and HOLDA codes indicate the particular type of internal cy- 
cle in progress. The AUMS or AUMSL code is output during accesses of external Macrostore. 

The MPILCK (multiprocessor interlock) condition is signified by BST = 0O0 and can remain in effect during an inter- 
nal cycle, as indicated by the AUMSL bus status code. 

Each internal cycle begins with an ALATCH pulse. During an internal cycle, a low READY signal will generate wait- 
states. Activity on the local bus interface during internal cycles is discussed in Section 10.6.4. 
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3.4 Applicable Bus Status Codes 
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in the following paragraphs. Each bus cycle - memory, I/O or internal - is accompanied by a bus status code con- 
sisting of the MEM and BST1 -BST3 output signals, as indicated in Table 2. The bus status code for each bus cycle 
becomes valid during the ALATCH pulse at the beginning of the cycle and remains valid through the remainder of 
the cycle. An access of internal Macrostore is classified as a special type of internal cycle and is accompanied by 
the AUMS or AUMSL bus status codes. 

3.4.1 Memory Read Cycle Codes 

=or all memory read cycles, MEM is active low. The bus status codes (from Table 2) differentiate the following 
types of memory read cycles: 

lAQ - instruction acquisition 

lOP - fetch data from the instruction stream {immediate operands, symbolic addresses, or second word of a 
two-word instruction) 

SOP - source operand 

SOPL - source operand with MPILCK asserted 

OOP - destination operand 

INTA - fetch of interrupt or XOP trap vector (WP and PC), including NMI and reset 

WS - workspace (Note that the WS bus status code will occur only when workspace register addressing is 
used. When the workspace is accessed via other addressing modes (i.e., symbolic), the WS code will not be 
output.) 

• GM - general memory 

During an indivisible (semaphore) operation, the MPILCK bus status code becomes active at the start of the source 
operand read cycle (Section 3.4.4). 

3.4.2 Memory Write Cycle Codes 



For all memory write cycles, MEM is active low. The bus status codes differentiate the following types of memory 
write cycles: 

• SOP - source operand 

• OOP - destination operand 

• WS — workspace (Note that the WS bus status code will occur only when workspace register addressing is 
used. When the workspace is accessed via other addressing modes (i.e. symbolic), the WS code will not be 
output.) 

• GM - general memory 

3.4.3 Hold Acknowledge Code - HOLDA 

The proces so r outp uts the HOLDA bus status code (Table 2) upon relinquishing the local bus in response to an ac- 
tive HOLD or APP input signal. 

3.4.4 Multiprocessor Interlock Code - MPILCK 

The MPILCK bus status code provides a means for implementing an indivisible test-and-set mechanism. Such a 
mechanism is required to insure system integrity in applications in which multiple processors communicate by 
means of semaphores located in shared memory. Whenever the processor outputs the MPILCK code, external 
logic inhibits memory accesses by the other processors in the system. The MPILCK signal is indicated by BST1 - 
BST3 = 000 (refer to Table 2), and is output during execution of the ABS (absolute value), TSMB (test and set), 
and TCMB (test and clear) instructions, as shown in Figure 1 7. The MPILCK code becomes valid during the source 
operand fetch (indicated by the SOPL code in Table 2) remains active through the internal cycle (AUMSL), and is 
removed as the next cycle (either an SOP or WS) begins. 
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, FETCH { ALU ! WRSTE 
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♦ 1(1) 



NOTES: 



(1 ) The SOPL or AUMSL code indicates that the lock is in effect through the next bus cycle. 

(2) If Ts = (register source operand), an interlock will not be performed. WS will appear instead of SOPL or SOP. 



FIGURE 17 - MULTIPROCESSOR INTERLOCK TIMING - ABS, TSMB, TCMB INSTRUCTIONS 



The MPILCK code is not output if the source operand for an ABS, TSMB or TCMB instruction is located in the 
worl<space. In this case, the SOPL-AUMSL-SOP bus status code sequence described above is replaced by WS- 
AUMS-WS. 



The T MS99000 does not inhibit the sampling of HOLD while MPILCK is active; the processor will respond to the 
HOLD signal by replacing its MPILCK bus status code with the HOLDA code and entering hold. Using the MPILCK 
signal to inhibit contention for shared memory is therefore not sufficient to insure the integrity of systems which 
allow DM A devic es to modify semaphore locations. In such systems, DMA devices must monitor MPILCK to avoid 
asserting HOLD during indivisible operations. 

3.4.5 Macrostore Accesses 

The AUMS or AUMSL (arithmetic logical unit or Macrostore) bus status code is used to indicate either a 
Macrostore access or an internal processing cycle; i.e., the same status code is used for both types of operation. 
The AUMS or AUMSL bus status code serves to distinguish accesses of external Macrostore from I/O accesses or 
accesses of the user's main memory. A complete description of Macrostore accesses is given in Section 7. 

4. INTERRUPT STRUCTURE 

4.1 TMS99000 INTERRUPT STRUCTURE 

The TMS99000 provides 1 6 interrupt levels, each supported by its own trap vector located in memory. The trap 
vector for each interrupt level is a two-word structure containing the WP (first word) and PC (second word) values 
of the service routine. When an interrupt occurs, the ensuing context change causes the processor's internal PC 
and WP registers to be loaded with the values from the corresponding trap vector. The locations of the trap vec- 
tors for the 1 6 interrupt levels are given in Table 3. Interrupt level is the highest priority, and level 1 5 the lowest. 
The reset function uses level 0. Level 2 is reserved for the illegal instruction trap, the privileged opcode violation 
trap, and (at the user's option) the arithmetic fault trap. The occurrence of the arithmetic fault and privileged viola- 
tion interrupts (when unmasked) causes the external maskable interrupts to be ignored until after the context 
switch for these interrupts has occurred. Levels 1 through 1 5 can be used for external device interrupts; level 
can also be used for external interrupts if external hardware is provided (Section 4.2). 
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TABLE 3 - INTERRUPT LEVEL DATA 





VECTOR LOCATION 




MASK VALUES 


VALUE MASK SET 


INTERRUPT 


(MEMORY ADDRESS 


DEVICE 


TO ENABLE 


TO UPON TAKING 


LEVEL 


IN HEX) 


ASSIGNMENT 


(ST12THRUST15) 


THE INTERRUPT 
(ST12-ST15) 


RESET 


0000 


External 


through F 





ILLOP 


0008 


Internal 


(see Note 4) 


1 


NMI 


FFFC 


External 


through F 





ARITHMETIC 


0008 


Internal 


(see Note 2, 3) 


1 


FAULT 










PRIVILEGED 


0008 


Internal 


(see Note 3) 


1 


VIOLATION 













0000 


External 


through F 
(see Note 1 ) 





1 


0004 


External 
device 


1 through F 





2 


0008 


External 
device 


2 through F 


1 


3 


OOOC 


" 


3 through F 


2 


4 


0010 


" 


4 through F 


3 


5 


0014 


" 


5 through F 


4 


6 


0018 


" 


6 through F 


5 


7 


001 C 


" 


7 through F 


6 


8 


0020 


" 


8 through F 


7 


9 


0024 


" 


9 through F 


8 


A 


0028 


" 


A through F 


9 


B 


002C 


" 


B through F 


A 


C 


0030 


" 


C through F 


B 


D 


0034 


" 


D through F 


C 


E 


0038 


" 


EandF 


D 


(Lowest F 


003C 


External 


F only 


E 


priority) 




device 







NOTES: (1) Level cannot be disabled. 

(2) Arithmetic fault Interrupt is generated internal to the Alpha and is enabled/disabled by bit 10 of the status register. 

(3) The occurrence of the arithmetic fault and privileged violation interrupts (when unmasi<ed) causes the external maslcabie Interrupts to be ignored 
until after the context switch for these interrupts has occurred. 

(4) The ILLOP (illegal instruction) interrupt is generated internal to the 99000 and cannot be disabled by the interrupt maslc. 



External device interrupt requests are transmitted to the processor through the INTREQ and IC0-IC3 input pins. 
The interrupt level, in t he range to 1 5, is encoded on the four IC (interrupt code) lines, and the interrupt request 
is g enerated by pulling INTREQ low. Figure 1 8 shows the timing for the external interrupt interface. Activatbn of 
the INTREQ input causes the processor to compare the interrupt code, IC0-IC3, with the interrupt mask in bits 1 2 
through 1 5 of the status register. If the level of the pending interrupt is less than or equal to the enabling mask 
level (higher or equal priority interrupt), the processor recognizes the interrupt and initiates a context switch as 
soon as the current instruction completes execution. The proce ssor then fetches the new context (WP and PC) 
from the appropriate trap vector and at the same time forces the PSEL output high, as indicated in Figure 1 8. Dur- 
ing the fetch of the new WP and PC values, the INTA (interrupt acknowledge) bus status code (Table 2) is output. 
Next, the previous context, consisting of the WP, PC and ST values from the interrupted program is stored in WRs 
13, 14 and 15, respectively, of the new workspace. Status bits 7 through 1 1 are cleared to insure that the 
arithmetic fault interrupt enable (ST10), map enable (ST8), and privileged mode (ST7) status bits are not carried 
over from the interrupted program. Next, the processor forces the interrupt mask to a value that is one less than 
the level of the interrupt being serviced, except in the case of a level interrupt, for which the mask is set to all 
zeros. This mechanism insures that the service routine for an external interrupt of level 1 through 1 5 will be inter- 
rupted only in the event that a higher-priority interrupt request is received. Upon switching to the service routine, 
the processor inhibits further interrupts until the first instruction of the service routine has been executed. 
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NOTES: 



(1) INTREQ and IC(0-3) are first sampled during the lAQ cycle, but if wait states occur in the cycle that follows the lAQ cycle, samples will continue to 
be taken until one clock before the end of that cycle. Only the last sample taken is examined by the processor's interrupt logic to determine whether 
to take the interrupt. Sampling occurs at the hIgh-to-low transition of CLKOUT. 

(2) The pref etched instruction will be discarded when the interrupt is accepted. 

(3) INTREQ is not sampled during the first instruction fetch following the interrupt context switch sequence . 

(4) Bus cycles, during which the AUMS bus status code is output, are omitted from the figure for simplicity. 

FIGURE 18 - INTERRUPT SEQUENCE 

In order to insure recognition of an interrupt request, the request should remain active until acknowledged either 
by software in the interrupt service routine or by hardware keyed to the INTA bus status code. If a software inter- 
rupt acknowledgment is used, the interrupt service routine must reset the interrupt request before the routine is 
completed. If hardware interrupt acknowledgment is used, the interrupting device must monitor four bits of the 
address bus (A10-A1 3) to determine which interrupt level is being acknowledged. In the event that an interrupt 
level is shared by more than one device, a hardware or software priority scheme must identify the interrupting 
device. 



The interrupt code on the IC0-IC3 inputs will continue to be sampled as long as INTREQ remains active low. If the 
code specifies an interrupt level that is disabled initially by the interrupt mask value, the INTREQ input can be held 
low until the processor alters the mask to a value that allows the interrupt request to be recognized. The external 
interrupt interface is synchronous. The IC0-IC3 inputs must be stable during the falling edge of CLKOUT at which 
time they are sampled. 

The interrupt vector is typically read from memory, but the system can be constructed so that the interrupting 
device itself supplies the interrupt vector via the memory bus. In this case, a hardware decoder triggered by the IN- 
TA bus status code and address bits AID to A1 4 (these indicate the interrupt level and whether the WP or PC 
value is being read) enables the interrupting device (and disables memory) when the processor fetches the inter- 
rupt vectors. 

Should the service routine for one interrupt level be interrupted by another interrupt of higher priority, a second 
context switch occurs to service the higher-priority interrupt. When the service routine for the higher-priority inter- 
rupt is complete, an RTWP instruction is executed to resume processing of the lower-priority interrupt. All inter- 
rupt service routines should terminate with the RTWP instruction to restore the context of the interrupted pro- 
gram. 
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4.2 INTERRUPT LEVEL AND RESET 

Ti.^ i»..<.i n *.-<»> ..a/N+nr ie • i+iii-iow kk bcth Tssst functlcp. 3P.d ths isvs! Q sxtsrns! intsrru'^t. Ths r@s6t function is sc- 
tivated by pulling the RESET in put low . As indicated in Figure 1 9, the processor samples RESET on each high-to- 
low transition of CLKOUT. The RESET signal cau ses th e processor to cease instruction execution at the end of the 
current bus cycle, and the WE/IOCLK, RD, and MEM signals are forced inactive high and RA/V is forced low in- 
dicating the AD bus will tristate. The processor remains in this state until RESET is released. 
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NOTES: 



( 1 ) The bus status codes during these cycles depend on the in structio n being performed at this time. 

12) RESET is sampled at every high-to-low CLKOUT transition. RESET is required to be active-low-for a minimum of three sample times so that the se- 
quence can occur correctly. 

(3) The reset context switch begins two CLKOUT cycles after RESET is sampled as having returned to the inactive-high level. 



FIGURE 19 - RESET SEQUENCE 



When RESET is released, a context switch to the level service routine is initiated. The processor acquires the 
new WP and PC values from the trap vector located at memory address 0; it stores the old WP, PC and ST values 
in the new workspace; and it clears all status register bits and all internal error interrupt status bits to 0. If NMI is 
not active, the processor fetches the first instruction of the reset service routine. Otherwise, the NMI trap occurs 
after the context switch for the reset trap completes, but before the first instruction of the reset routine is ex- 
ecuted. 



A level external interrupt is requested by pulling the processor's INTREQ input low while IC0-IC3 are all low. In 
general, the use of the level interrupt requires that the request be removed when the INTA bus status code is 
output. Otherwise, the interrupt will be accepted a second time since it cannot be masked, and the return context 
will be lost. Note that the level external interrupt is not the same as RESET but rather an external nonmaskable 
interrupt which uses the same trap vector as RESET. 
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4.3 



NON-MASKABLE INTERRUPT (NMI) 



The NMI cannot be masked out. It is enabled by all values of the interrupt mask. The NMI implements ROM 
loaders, single-step and breakpoint f uncti ons for maintenance panels, and other user functions. An NMI request is 
generated by pulling the processor's NMI input low. This signal and its associated function are named "LOAD" in 
some previous 9900 family products. 

An NMI request is handled according to the basic interrupt timing sequence described previously. The timing for 
the NMI is presented in Figure 20. As shown in Table 3, the NMI trap vector resides at memory address FFFC. The 
interrupt mask is automatically cleared when an NMI occurs. 
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NOTES: 



(1) 
(2) 



(3) 



NMI is always sampled but will not be acknowle dged until after the lAQ cycle. 

After an NMI context switch has been i nitia ted, NMI can remain active low indefinitely without causing another NMI request to be generated. In 

order t o gen erate another NMI request, NMI must be taken inactive high and be sampled at least once at the inactive level before being activated 

again. (NMI is sampled on the high-to-low transition of CLKOUT.) 

The prefetched instruction will be discarded as soon as the NMI request is recognized. 



FIGURE 20 - NMI SEQUENCE 



The processor almost always grants NMI request immediately following completion of the current instruction. The 
only exceptions to this statement are user-defined instructions emulated in Macrostore that use opcode >0384 to 
exit Macrostore (described in Section 7). 

4.4 INTERRUPT LEVEL 2 

The level 2 trap vector is used for external interrupts as well as for the following internal trap conditions: 
arithmetic fault, illegal instruction, and privileged opcode violation. Sampling of the level 2 external interrupt (and 
of all other interrupts as well) is delayed until the end of each instruction (Figure 1 8) to facilitate non-ambiguous 
error reporting. An error detected by external logic during execution of an instruction will be recognized (if level 2 
interrupts are enabled) before the next instruction is executed. The PC value stored during the level 2 context 
switch points to the instruction following the one which generated the error. The external level 2 interrupt should 
be reserved for system errors such as memory faults and access violations. A memory error generated by the in- 
struction prefetch should be delayed for one non-DMA bus cycle by external logic to insure that the memory error 
is associated with the prefetched instruction rather than with the instruction preceding it. 
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The error interrupt status bits are located at the I/O addresses shown in Table 4. Appropriate bits defined in 
Table 4 are set at the time the error occurs. A level 2 interrupt request is generated as long as any bit in the error 
status register, except the ILLOF (iiiegai instruction) flag, is set. The ILLOP flag is set under control of Macrostore 
emulation software, as described in Section 4.4.3. The error status bits can be examined by the level 2 interrupt 
service routine to determine the cause of the interrupt. The active bit(s) must be reset using a bit I/O operation 
(SBZ or LDCR) to acknowledge the condition and remove the interrupt request. This is not strictly necessary in the 
case of the ILLOP flag since it does not generate an interrupt request. 



TABLE 4 - ERROR INTERRUPT STATUS BIT ASSIGNMENTS 



ERROR FLAG 


I/O ADDRESS 1 


INPUT BIT 


OUTPUT BIT 


PRIVOP (privileged violation) 

ILLOP (illegal instruction code) 

AF (arithmetic overflow - ST4 and ST 10 on) 


>1FDC 
>1FDA 
>1FC8 


>1FDC 
>1FDA 
>1FC8 



Each bit is individually cleared by writing a to the bit, e.g., by means of an SBZ or LDCR instruction. When I/O in- 
put operations are performed, the external IN input line is ignored. Writing a 1 to I/O address locations > IFCO to 
> IFC7 will cause all three flags (PRIVOP, ILLOP and AF) to be set to 1 . Writing a 1 to > IFD3 or > IFD4 will set the 
ILLOP or PRIVOP flag to 1 , respectively. 

When a level 2 interrupt has occurred, the level 2 service routine reads the I/O error interrupt status bits using the 
STCR or TB instruction to identify the source of the error. The interrupt is cleared by writing a to the appropriate 
bit. The error interrupt status bits are automatically cleared by executing any of the following operations: 

• RSET instruction 



• Reset function (external device pulls RESET input low) 

• I/O output operations to the bit(s) I/O address. 

4.4.1 Arithmetic Fault Interrupt 

The TMS99000 can be programmed to generate an interrupt when an overflow occurs during an arithmetic opera- 
tion. This permits arithmetic fault checking to be performed without software overhead. The arithmetic fault inter- 
rupt is controlled using three programmable flags: bits 4 and 1 of the status register (Table 1 5) and AF of the er- 
ror interrupt status bits (Table 4). ST4 is the arithmetic fault flag and is set to 1 whenever an overflow occurs. 
ST 1 is the arithmetic fault enable bit and is set or cleared by the programmer to enable or disable, respectively, 
the arithmetic fault interrupt. AF of the error status register is automatically set when both ST4 and ST10 are 1 . 
When set and the interrupt mask is greater than or equal to 2, AF generates a level 2 interrupt request, which is 
handled according to the standard interrupt sequence described in Section 4.2. 

If an arithmetic overflow occurs while ST 1 is 1 and the interrupt mask contains a value in the range 2 through 
1 5, a level 2 interrupt occurs directly upon completion of the instruction causing the overflow. The PC value saved 
during the resulting context switch is the address of the first word of the instruction immediately following the in- 
struction that caused the overflow. 

The level 2 interrupt service routine must check ST4, ST 1 of the saved status register in the routine's workspace 
register 1 5 (WR1 5) and AF to determine that the interrupt was caused by an overflow. The service routine, whk:h 
is invoked by the arithmetic fault interrupt, must clear the AF bit and either bit 1 or bit 4 of WR1 5 before return- 
ing to the routine which caused the overflow. If this procedure is not followed, the arithmetic fault will falsely oc- 
cur immediately upon the completion of the RTWP instruction. 

Should the level 2 interrupt service routine be interrupted, in turn, by a higher-priority interrupt, the arithmetic fault 
condition is retained in AF until the program explicitly clears it. Similarly, ST4 and STIC are preserved when the 
status register is saved during the context change; they are restored upon return from the higher-priority interrupt. 
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4.4.2 Macroinstmction Detection (MID) Trap 

The MID trap permits the detection of illegal opcodes and the emulation of opcodes not defined in the processor in- 
struction set. Emulation can be performed either in hardware or software. Hardware emulation takes place using 
the attached processor interface discussed in Section 8. Software emulation routines are contained in the 
Macrostore, described in Section 7. 

The acquisition of an undefined opcode during an instruction fetch causes an MID trap to occur immediately 
before the processor attempts to execute the instruction. A list of the opcodes, which cause the MID trap, are 
listed in Section 10.5.19 and consists of all opcodes undefined in the basic instruction set of the processor. 
These are referred to as MID opcodes. The XOP instruction is also treated as an MID opcode in the event that bit 
1 1 of the status register is set to 1 . 

Whenever the processor detects an MID opcode in the instruction stream, a check is made to determine whether 
an attached processor is prepared to execute the instruction. 

If not, program control is transferred to the external Macrostore in the case of the TMS99105 or internal 
Macrostore in the case of the TMS991 1 to allow the instruction to be emulated in software (see Section 4.4.4). 

The sequence of actions that takes plac e durin g an MID trap is as follows. Upon detecting an MID opcode, the pro- 
cessor outputs an MID bus status code (MEM = 1 , BST = 1 1 0). If an attached processor is prepared to execute the 
instruction, it responds to the MID status code by pulling the processor's APP input low. If APP remains inactive, 
program control is transferred to the Macrostore. The PC saved during the context switch points to the word 
following the MID opcode, if the MID opcode is followed by immediate data or address information, the emulation 
routine can use the saved PC value to access this information. In a likewise manner the program may use the sav- 
ed workspace pointer (WP) to access operands in the calling routines workspace. 



The MID trap is non-maskable and is higher in priority than any other interrupt except the reset function (RESET 
active low). An MID opcode always results in an MID trap regardless of the value of the interrupt mask. If an NMi 
request is received at the same time that an MID opcode is detected, the MID trap sequence will take place first 
and be followed immediately by the NMI sequence before the attached processor or Macrostore software begins 
to emulate the MID instruction. This permits the NMi input signal to control single-stepping in conjunction with 
MID opcodes and microcoded processor opcodes alike. 

When a user program attempts to execute an MID opcode that is defined neither by an attached processor nor by a 
Macrostore emulation routine, the Macrostore software should detect this fact and initiate a level 2 interrupt. This 
is accomplished by the special form of the RTWP instruction (opcode >0382), which causes the processor to set 
the ILLOP bit of the error status bits and then exit Macrostore memory space. This provides an indicator to the 
level 2 trap routine undefined opcode violation. If Macrostore is disabled at Reset, then an MID opcode will 
automatically cause the ILLOP bit to be set and a level 2 trap to occur. 

4.4.3 Illegal Instruction (ILLOP) Interrupt 

The illegal instruction interrupt is a result of a Macrostore exit through the execution of the special form of the 
RTWP instruction (opcode >0382) when in Macrostore (section 4.4.2). The level 2 interrupt routine can identify 
the illegal instruction interrupt by interrogating the ILLOP bit of the error status bits. 

This method is not reliable in detecting illegal instructions within level or level 1 interrupt routines. The context 
linkage may be lost if two successive level or level 1 external interrupts occur unless a software stack is created. 

The ILLOP trap permits the system to respond to illegal opcodes. When an illegal opcode is first encountered, the 
processor performs two preliminary checks before setting the ILLOP error interrupt status flag and vectoring to the 
level 2 interrupt routine. First, the processor outputs the MID (macro-instruction detected) bus status code to 
determine whether an attached processor is prepared to execute the instruction. If not, the processor transfers 
control to the emulation software in Macrostore to determine whether it recognizes the opcode. If this test also 
fails, the opcode is illegal. The Macrostore software sets the ILLOP flag and returns control to the user's program 
in main memory. The processor traps immediately to the level 2 interrupt routine before it has a chance to resume 
execution of the user's program. Once the trap has occurred, the level 2 interrupt routine checks the ILLOP flag to 
determine if the trap was caused by an illegal instruction. The ILLOP interrupt is non-maskable. 
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For further information, refer to the discussion of MID opcodes in Section 4.4.2. 

4.4.4 Privileged Opcode Violation Interrupt 

When a privileged opcode violation occurs, as described in Section 6, PRIVOP, the error interrupt status bit is set 
and, if the interrupt mask is greater than or equal to 2, generates a level 2 interrupt request. The offending instruc- 
tion is permitted to complete any operand fetches it requires, but following detection of the violation, all further at- 
tempts to write to the I/O address space are inhibited. As soon as the offending instruction completes execution, a 
level 2 interrupt takes place unless the interrupt mask value is or 1 . The trap sequence for the level 2 interrupt 
consists of a standard context switch, after which program control is transferred to the level 2 service routine. The 
routine checks the PRIVOP bit to determine if the interrupt was caused by a privileged opcode violation. PRIVOP 
should be cleared by the service routine before returning; otherwise, another level 2 interrupt will occur upon 
return unless the interrupt mask is set to a value of or 1 . 

If a privileged opcode violation occurs while the interrupt mask is or 1 , the level 2 interrupt is disabled and does 
not take place. The PRIVOP bit is still set, and any write operations attempted by the offending instruction are in- 
hibited as before. Execution of succeeding instructions will occur normally, however, until the interrupt mask is 
set to a value of 2 or greater, at which point the PRIVOP bit, which has remained set, causes a level 2 interrupt to 
occur. 

4.4.5 Applicable Bus Status Codes 

The INTA (interrupt acknowledge) bus status code is output by the processor to indicate that a reset, NMI, XOP (if 
ST1 1 =0), external interrupt or any of the level 2 interrupts is in progress. The INTA is output during the fetch of 
the WP and PC values from the trap vector for the interrupt or XOP. 

If desired, the INTA bus status code can be used as a signal to automatically acknowledge an interrupting device. 
The acknowledgment signal is generated by hardware external to the processor that can recognize the INTA code 
and determine the interrupt level by decoding address bits A10 through A13. 

5. TMS99000 INPUT/OUTPUT INTERFACE 

5.1 DESCRIPTION 

The TMS99000 provides both bit-serial and bit-parallel I/O to meet the requirements of both bit, byte and word 
peripheral applications. TMS99000's I/O is a command-driven direct I/O interface that supports bit, byte and 
word data transfers. The I/O address space contains 32768 peripheral input locations, and 32768 output loca- 
tions. The first 1 6384 I/O addresses (input or output) are bit locations accessed in bit-serial fashion; the last 
1 6384 I/O addresses are word or byte locations (as specified by the user) accessed in bit-parallel fashion. Figure 
21 provides the I/O address map for the TMS99000. 
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BiT-SERIAL i/0 SPACE 
(MSB OF BASE ADDRESS IS 0) 



BJT-PARALLEL !/0 SPACE 
(MSB OF BASE ADDRESS IS 1) 



0000 



8000 



1BFE 
1C00 

1EC4 
1ECE 

1FC0 
1FE0 

7FFE 



NON-PRIVILEGED I/O ADDRESS SPACE 



PRIVILEGED I/O ADDRESS SPACE 



EXTERNAL 
INSTRUCTIONS 



ERROR STATUS 
INTERRUPT BITS 




BIT ADDRESS = BASE 
ADDRESS IN WR1 2 + 
BIT NUMBER* 2 



FFFE 



WORD OR BYTE ADDRESS 
= BASE ADDRESS IN WR12 



FIGURE 21 - I/O ADDRESS MAP 



The I/O interface utilizes the same signal lines as the interfaces for main memory and external Macrostore, as in- 
dicated in Figure 22. The I/O address space, however, is logically distinct from the memory and macrostore ad- 
dress spaces. The timing for I/O read a nd wri te operations is presented in Figures 23 and 24. I/O operations are ac- 
companied by the I/O bus status code (MEM = 1,BST = 01 1 ) to distinguish them from accesses of memory or ex- 
ternal Macrostore. (In fact, only two signals, MEM and BST2, are required for this purpose; see Table 2.) 
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FIGURE 22 - TMS99000 I/O INTERFACE 
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NOTES: 



(1) Valid address, PSEL high (internal ST8=0) 

(2) Bus in input mode (drivers are tristated) 

(3) If MSB of address is 0, I/O bit must be valid on DO/I/IN. If MSB of address Is 1 , 1/0 word must be valid on A/D(0-1 5), and I/O byte on A/D(0-7). 

(4) READY is sampled at this time. 

FIGURE 23 - TMS99000 1/0 TIMING - INPUT OPERATION 
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NOTES: 



(1) Address is valid, and PSEL is high (internal ST8=0). 

(2) If MSB of address is 0, then valid I/O bit is on D1 5/OUT. If MSB of address is 1 , then valid I/O word is on A/D(0-1 5), and I/O byte is on A/D(0-7). 

(3) READY is sampled at this time. 

FIGURE 24 - TMS99000 I/O TIMING - OUTPUT OPERATION 



Each I/O cycle begins with an ALATCH pulse, the falling edge of which latches externally the 1 5 address bits AG 
to A1 4 and the PSEL page select signal. If AO, the MSB of the address, is 0, a bit-serial I/O operation is perfo rmed; 
if AO is 1 during an LDCR or STCR instruction, a bit-parallel (byte or word) I/O operation is performed. The PSEL 
output signal is forced high during all I/O cycles regardless of the actual state of ST8 of the processor's status 
register (Section 2.3.2). Following the ALATCH pulse, data is input or output on the address-data lines and R/W is 
taken high or low to indicate whether an input or output operation is to be performed. Serial I/O accesses utilize the 
AO/DO/IN line for reads, and the PSEL/D1 5/OUT line for writes. Parallel I/O operations utilize all 16 data lines 
(D0-D1 5) for word transfers, and the first eight (D0-D7) for byte transfers. I/O write operations are accompanied 
by a low pulse on the WE/IOCLK output; I/O read operations are accompanied by a low pulse on RD. 

The minimum-length I/O cycle is two machine states (two CLKOUT periods) in duration. If, during the second 
machine state of a I/O cycle, READY is low, the cycle is extended by one wait-state. Holding READY low 
generates additional wait-states until READY is taken high prior to the high-to-low transition of CLKOUT. Figure 
25 illustrates the relationship between I/O wait states and the READY line. 
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NOTES: 

(1 ) First sample time of READY in I/O cycle. 

(2) Second sample time of READY in I/O cycle. Additional wait states are generated by keeping READY low at this and subsequent sample times. 

(3) XXXXXX denotes don't care. 



FIGURE 25 - WArT-STATE GENERATION FOR I/O CYCLES 



The TMS99000 instruction set contains five l/O-oriented instructions. Three of the I/O instructions are used to 
perform single-bit operations in the first 1 6384 bits of the I/O address space. (See Figure 22J These are the TB 
(test bit), SBO (set bit to one) and SBZ (set bit to zero) instructions. The remaining two I/O instructions perform 
multiple-bit operations in either bit-serial or bit-parallel fashion, depending on which half of the I/O space is being 
addressed. 

5.2 SINGLE-BIT I/O OPERATIONS 

The single-bit instructions facilitate the testing and/or modification of a particular bit in a device. The three single- 
bit I/O instructions, TB, SBO and SBZ, are executed as follows. The TB instruction reads the bit from the address- 
ed I/O location onto the AO/DO/IN line, and this bit is placed in status register bit 2 (EQ). The SBO instruction out- 
puts a one on the PSEL/D1 5/OUT line, and the SBZ outputs a zero on this line. 

The processor develops the address for a single-bit I/O operation from the base address contained in bits to 1 4 
of WR12 and from the signed displacement field contained in bits 8 to 1 5 of the instruction. As indicated in 
Figure 26, the signed displacement *2 is added to the base address to generate the effective I/O address output 
onto the bus. The displacement allows two's complement addressing from base - 1 28 through base-f 1 27. Note 
that for single-bit I/O instructions, SBO, SBZ, and TB, the most-significant bit of WR1 2 does not affect the opera- 
tion (i.e., no parallel operations). 
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FIGURE 26 - SINGLE-BIT I/O ADDRESS DEVELOPMENT 



5.3 MULTIPLE-BIT SERIAL I/O OPERATIONS 

The STCR and LDCR instructions specify multiple-bit I/O operations. The starting address in I/O address space is 
loaded into WR1 2 prior to executing STCR or LDCR. When the MSB (bit 0) of the address in WR1 2 is 0, the 
transfer is performed in bit-serial fashion rather than in parallel. During a multiple-bit, bit-serial I/O transfer, the first 
bit is read from or written to the address pointed to by bits through 1 4 of WR1 2. Consecutive bits are read from 
or written to I/O locations separated by an address increment of -i- 1 . The contents of WR1 2 are not altered by ex- 
ecution of the serial STCR or LDCR instructions. 

A multiple-bit serial I/O transfer is represented in Figure 27. Although a full 16-bit transfer is indicated in the 
figure, any number of bits from one to 1 6 can be specified. The transfer mechanism results in an order reversal of 
the bits; that is, bit 1 5 of the memory word (or bit 7 of the byte) corresponds to the bit stored at the lowest I/O ad- 
dress, and bit corresponds to the bit stored at the highest I/O address. 
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FIGURE 27 - LDCR/STCR DATA TRANSFERS 



The first word of an STCR or LDCR instruction contains a 4-bit CNT (count) field, wliich specifies the number of 
bits to be transferred. If CNT is 0, then 1 6 bits are transferred. If CNT is in the range 1 to 8, the effective source 
operand address from the STCR or LDCR instruction is treated as a byte address; otherwise, it is treated as a word 
address. 

The LDCR instruction reads a word lor byte) from the memory and writes all or part of it to the I/O in bit serial 
fashion. Beginning with the rightmost bit in the word (or byte) and moving from right to left, each consecutive bit 
is output through the I/O interface until the specified number of bits has been transferred. 

The STCR instruction reads data from the I/O and transfers it to memory. If the specified number of bits to be 
transferred from the I/O is less than 9, they are stored right-justified in the addressed memory byte, and the 
leading bits are cleared to 0. If the operation involves from 9 to 1 6 bits, the data is stored right-justified in the ad- 
dressed memory word, and the leading bits cleared to 0. When the instruction is completed, the bit from the 
lowest I/O address occupies the LSB position in the memory word or byte. 

5.4 PARALLEL I/O OPERATIONS 

When the MSB (bit 0) of the I/O base address in WR1 2 is 1 , the multiple-bit I/O transfer specified by an STCR or 
LDCR instruction takes place in a single I/O transfer, i.e., in parallel. Either a word or byte is transferred as deter- 
mined by the 4-bit CNT field in the first word of the LDCR or STCR instruction. If the CNT field is within the range 
of 9 to 1 5, then a word is transferred. If the CNT field is within the range 1 to 8, then a byte is transferred. For 
parallel I/O, CNT is restricted to (binary) 0010, 001 1, 1010, and 101 1. The CNT field selects the mode of 
transfer as shown below: 

if CNT = 0010, then byte transfer 

if CNT = 001 1 , then byte transfer with WR1 2 auto increment 

if CNT = 1010, then word transfer 

if CNT = 1011, then word transfer with WR1 2 auto increment. 

The automatic increment of WR12 is provided to facilitate block transfers of data to and from devices in the 
parallel I/O address space. 

5.5 APPLICABLE BUS STATUS CODES 

I/O cycles are identified by the I/O bus status code (Table 2). 
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5.6 EXTERNAL INSTRUCTIONS 

The TMS99000 has five external instructions that allow user-defined off-chip functions to be initiated under pro- 
gram control. These instructions are CKON, CKOF, RSET, IDLE and LREX. These names are arbitrary. The user 
may define the external function performed by these instructions. 

Execution of CKON, CKOF, RSET or LREX causes a bit value of to be written to one of the I/O addresses 
specified in Table 5. Following the single I/O write cycle, execution proceeds to the next instruction. RSET is the 
only external instruction that can affect the ST (status) register or the error interrupt status bits. In privileged mode 
(ST7 =0), RSET causes ST9-ST1 5 and the AF, ILLOP, and PRIVOP bits of the error status bits to be cleared. This 
is followed by a status update cycle (ST bus status code) to notify external devices of the change in status. In user 
mode (ST7 = 1 ), the ST and error status bits are unaffected, and RSET is similar in effect to CKON, CKOF and 
LREX. 

TABLE 5 - EXTERNAL INSTRUCTION CODES 



INSTRUCTION 


I/O BASE ADDRESS 


IDLE 


1EC4 


RSET 


1EC6 


CKOF 


1ECC 


CKON 


1ECA 


LREX 


1ECE 



IDLE differs from the other external instructions in t hat its f unct ion is predefined. Execution of IDLE causes the 
processor to enter and remain in the idle state until a RESET, NMI or unmasked e xternal inte rrupt occurs. While in 
the idle state, a bit value of is written repeatedly to I/O address >1 EC4 (i.e., the WE/IOCLK output is pulsed con- 
tinually). Upon leaving the idle state, a context switch takes place to service the interrupt. The PC value saved dur- 
ing the context switch points to the address of instruction following the IDLE instruction. 

The timing for the I/O write operation, or operations in the case of IDLE, follows that given in Figure 24. Each I/O 
write cycle is accompanied by the I/O bus status code (Table 2). 



When the processor receives a hold request (HOLD low) while in the idle state, the processor enters the hold state 
directly from the idle state. It reenters the idle state as soon as the hold request is deactivated. 

PRIVILEGED MODE 

For hardwired system protection in a user/supervisor programming environment, certain instructions performing 
I/O and control functions are designated as "privileged". When the system is placed in the user or "non- 
privileged" mode, any attempt to execute one of these instructions will result in abortion of the instruction and an 
interrupt request through the level 2 trap vector. (See Section 4J 

The system can be placed in the user mode by setting status bit 7 to 1 by means of an LST or RTWP instruction. 
The system is placed in the pri vileged mode by the occurrence of any interrupt, execution of the XOP instruction, 
by the assertion of the NMI or RESET input signals, or during Macrostore operations. 

When a privileged opcode violation is detected, error status bit PRIVOP is set, and this, in turn, generates a request 
for a level 2 interrupt as described in Section 4.4.3. The following instructions are privileged: CKON, CKOF, IDLE, 
LIMI, LREX and RSET. The use of the following instructions is qualified in user mode: LDCR (I/O), RTWP, SBO 
(I/O), SBZ (I/O), and LST. In processors with LDD and LDS instructions implemented in Macrostore such as the 
TMS991 10, these instructions are privileged. Section 10.5 should be consulted to determine the restrictions 
placed on each of these instructions in user mode. 

The LDCR instruction is a privileged instruction for byte and word transfers to output addresses falling within the 
range specified by Figure 21 . Similarly, the SBO, SBZ I/O instructions are privileged for bit I/O operations falling 
within the same range. 
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The LST operation is dependent upon whether the processor is in the privileged or non-privileged mode when the 
instruction is executed. While in the orivileaed mode <ST7=0V the i c;t inetr. .oti«r. «,«^i*!«<. on ic i.:— »* *u_ 
status register. While in user mode (ST7 = 1 ), only bits through 5 and bit 1 of the workspace register specified 
in the W field are placed in the status register, and loading these bits has the side effect of clearing ST6. Similarly, 
return workspace pointer (RTWP) instruction will cause all bits of the status register to be replaced when in 
privileged mode and only the seven bits discussed when in a non-privileged mode. 

Section 10.5 discusses the operation of these instructions in more detail. 
7. MACROSTORE INTERFACE AND OPERATION 

7.1 DESCRIPTION 

Macrostore is a special feature of the TMS99000 that permits new instructions to be defined and emulated in a 
manner completely transparent to programs residing in main memory. It provides the capability for adding new 
functions and enhancing the performance of specific kernels of software, thereby increasing the total system per- 
formance. Macrostore permits software kernels to be encapsulated within the TMS99000 system in a manner 
that makes them virtually indistinguishable in operation from functions implemented in hardware. This is ac- 
complished by providing a 64K byte address space that is logically distinct from the main memory and I/O address 
spaces. Macrostore functions as a control store for the TMS99000 but is programmed in assembly language 
rather than microcode. Internal to the TMS99000 are 1 024 bytes of Macrostore ROM (MROM) and 32 bytes of 
Macrostore RAM (MRAM). The access time of the on-chip Macrostore is one machine state. Emulation routines in 
the internal Macrostore execute at the full speed of the processor since no wait states are required to access the 
on-chip MROM and MRAM. While executing in the Macrostore, certain control capabilities are provided that are 
not available to programs executing in the main memory. 

7.2 THE MACROSTORE INTERFACE 

7.2.1 Timing 

The timing signals generated during accesses of external Macrostore are identical to the memory timing described 
in Sections 3.2.1 and 3.2.2, with the following exceptions. The only bus status codes (Table 2) output are the 
AUMS and AUMSL codes. (AUMSL is output if an ABS, TSMB or TOMB instruction is executed in Macrostore. 
Otherwise, AUMS is output.) 



Another difference between Macro store accesses versus main memory accesses is the operation of the PSEL out- 
put. In main memory accesses, the PSEL output represents the inverted state of the ST8 bit of the status register 
unless a long distance source/long distance destination instruction (LDS, LDD) is in effect (see Section B.3). (The 
LDS and LDD instructions apply to th eTMS 991 1 only; see Appendix B.) If a LDS or LDD instruction is in effect 
per the description in Appendix B, the PSEL output will represent the logic state of the STB bit without inversion. A 
complete d escrip tion of the LDS and LDD instructions is given in Appendix B, Section B.3. For Macrostore ac- 
cesses, the PSEL output is not guaranteed; thus it should not be used for paging Macrostore memory. 

The AUMS and AUMSL bus status codes differentiate between external Macrostore accesses and memory and I/O 
accesses. 



7.2.2 Wait States 



Accesses of on-chip Macrostore require only a single machine state to complete. If the Macrostore is extended us- 
ing an external RAM or ROM that is too slow to respond in a single machine state, external control logic must 
cause wait-states to be generated by pulling the 99000's READY input low until the access is ready to complete. 
The generation of wait-states is identical to main memory wait state generation described in Section 3.2.5. 



7.2.3 Organization 



The internal Macrostore consists of 1024 bytes of MROM and 32 bytes of MRAM. The MROM resides at addresses >0800 
to >OBFE. The MRAM resides at addresses >0000 to >001E and serves as workspace storage during Macrostore 
execution. External Macrostore may be added in the form of off -chip ROM or RAM residing at addresses in the range 
>1000 to > FFFE.' A map of the Macrostore address space appears in Figure 28. 
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FIGURE 28-ADDRESS MAP OF MACROSTORE 



7.2.4 Modes of Operation 



The TMS99000 operates in one of three modes which determine the operation of Macrostore. These modes are 
summarized in Table 6 and in the following paragraphs. 

TABLE 6 - MACROSTORE OPERATING MODES 



MODE 


EFFECT 


ENTRY PROCEDURE 


Standard 


On-chip ROM (1K bytes) and 
RAM (32 bytes) is assumed. 
External Macrostore memory 
expansion from > 1 000 through 
>FFFE. 


APP pin is a high 
level at reset. 


Prototyping 


On-chip ROM address range 
(>0800->0FFE) is mapped 
off-chip for use of external 
Macrostore memory. On-chip 
RAM is available. 


APP pin is taken 


low when RESET is 
pulled low and 
is released when 


RESET is released. 


Baseline 


All Macrostore memory space 
is disabled and the attached 
processor interface is 
disabled. 


APP pin is tied 
to ground.* 



Mf APP is brought high anytime after RESET, the processor will enter the prototyping mode. 
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7.2.4.1 Standard Mode 



in sianuaru moue, me on-cnip tvinv/m ana mnMivi are ootn enaoiea, permitting tne firmware contained in the 
MROM to be utilized. Du ring accesses of on-chip MROIVI and MRAM, the AUIVIS and AUIVISL status codes are out- 
put, and the WE/IOCLK and RD outputs both remain inactive high. 

While executing in Macrostore, a read or write to a Macrosto re address in the range > 1000 to > FFFE results in an access 
of external Macrostore. During this access, either the RD or WE/IOCLK output goes active low, depending on whether 
the Macrostore location is being read from or written to. The timing for the access is the same as that described for an 
access performed by a program residing in main memory, as described in Section 3.2, with the exception that the only bus 
status codes output are AUMS and AUMSL. This is consistent with the treatment of Macrostore execution as a special 
type of internal operation. The AUMS and AUMSL bus status codes are used by external decode logic to distinguish 
accesses of external Macrostore from accesses of main memory and I/O locations. Accesses of e xternal Macrostore are, in 
turn, distinguished from other kinds of internal operations by observing the RD and WE/IOCLK outputs, which are active 
during Macrostore accesses, but not during other types of internal operations. 



The TMS99000 is placed in standard mode by keeping the APP input high while RESET is pulled low at system initializa- 
tion. 



7.2.4.2 Prototyping Mode 



In prototyping mode, the TMS99000's internal MROM is disabled, but the MRAM remains enabled. A read or write to a 
Macrostore address in the range >0000 to >001E results in an access of the on-chip MRAM, but a read from or write to 
an y Macrostore address in the range >0800 to > FFFE results in an external Macrostore access. As in the standard mode, 
the WE/IOCLK and RD outputs are active only when the Macrostore read or write is off-chip. The AUMS and AUMSL bus 
status codes are output during accesses of both internal and external Macrostore. 



The processor is placed in prototyping mode by pulling the RESET and APP inputs lo w togeth er durin g system initializa- 
tion and releasing them at the same time, in systems without attached processors, the RESET and APP pins can simply be 
tied together. 

One use of prototyping mode is to permit external RAM or ROM occupying Macrostore addresses > 0800 to >0BFE to 
emulate on-chip MROM during development and testing of Macrostore software. 

7.2.4.3 Baseline Mode 

In baseline mode ail Macrostore memory space is disabled. In the event a MID opcode is encountered, the 
TMS99000 will cause a level 2 interrupt to occur and the ILLOP bit of the error status register (Section 4.4) will be 
set. The level 2 interrupt routine then may emulate the opcode or the opcode may be handled as an illegal opcode 
violation. In baseline mode the attached processor interface is also disabled. Thus the APP input pin will not be 
tested on the occurrence of a MID opcode. The level 2 interrupt will be implemented immediately. 

The TMS99000 is placed in baseline mode by pulling the APP input low at reset. It remains in baseline mode as 
long as AAP remains low. Typically, this is accomplished simply by tying APP to ground. (Note that if APP goes 
high after RESET, the processor will enter the prototyping mode.) 

7.3 MACROSTORE CAPABILITIES 

7.3.1 Entry Procedure 

When the TMS99000 is executing a program residing in main memory and a MID opcode is encountered, the APP 
pin is tested to determine whether an attached processor is prepared to respond to the MID opcode. If not, pro- 
gram control is transferred to the Macrostore. A MID opcode is an undefined opcode in the basic TMS99000 in- 
struction set, or an XOP executed while ST1 1 = 1 . 

The Macrostore is entered via an entry point table occupying the first ten words of the MROM, shown in Table 7. Each 
entry in the table contains the start address in MROM of an emulation routine for a particular group of MID opcodes. When 
a MID opcode is encountered in the program in main memory, instruction execution transfers to the MROM address in the 
entry-point table corresponding to that opcode. Undefined single-word opcodes are divided into eight groups with the 
entry addresses for each group as indicated in Table 7. Undefined two-word opcodes are treated as a 9th group, and XOPs, 
whenSTII = 1, as a 10th. 
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TABLE 7 - MACROSTORE ENTRY VECTORS 



TABLE 
LOCATION 



0800* 
0802* 
0804* 
0806* 
080 A* 
080A* 
0800* 
080E* 
0810 

0812 



MID^ 
OPCODES 



0000-001 B, 001E-0028, 002B-007F, OOAO-OOAF, OOCO-OOFF 

0100-01 3F 

0210-021F, 0230-023F, 0250-025F, 0270-027F, 0290-029F, 02B0-02BF, 02D0-02DF, 02E1-02FF 

0301-031F, 0320-033F, 0341-035F, 0361-037F, 0381-039F, 03A1-03BF, 0EC1-03DF, 03E1-03FF 

0C00-0C08, OCOC-OCFF 

ODOO-ODFF 

OEOO-OEFF 

OFOO-OFFF, 0780-07FF 

AM, SM, SRAM, SLAM, TMB, TOMB, TSMB 

(if the second word is illegal) 

XOPlif ST11=1) 



*Bits 5, 6 and 7 of the MID Opcode select one of eight entry-table locations. 

^The opcodes reserved for the LDD and LDS Instructions should not be used as MID opcodes. 



A context switch occurs after the entry-point address has been read from the table. The workspace pointer is set to 0000 
and the program counter is set to the address from the entry-point table. The old WP, PC, and status are saved in the 
MRAM locations corresponding to WR13, WR14and WR15, respectively. The PC value saved in WR14 always points to 
the word immediately following the MID opcode. If a two-word MID opcode was encountered, the PC value always points 
to the word immediately following the first word of the two-word opcode. 

Prior to transferring program control to the Macrostore emulation software, the MID opcode responsible for causing the 
MID trap is automatically placed in registers 3 and 5 of the Macrostore workspace. If the first word of an instruction causes 
the MID trap, the (entire) first word is placed in WR5. If the second word of an instruction causes the MID trap, the (entire) 
second word of the instruction is placed in WR5, and bits 1 0, 1 1 , 1 4, and 1 5 of the first word of the instruction 
are placed into bits 1 0, 1 1 , 1 4, and 1 5 of WR3. In the latter case, bits 1 0, 1 1 , 1 4, and 1 5 are sufficient to uni- 
quely identify the possible first word of an opcode in which the second word is illegal. The identification is per- 
formed as follows: Table 8 enumerates all the 2-word opcodes in the TMS99000 instruction set. These instruc- 
tions are divided into 3 groups. Bits 10 and 1 1 identify the group. Each group contains 2 or 3 opcodes. Bits 14 
and 1 5 serve to identify the individual opcodes within each group. 



WR3 IN MACROSTORE: 



1 2 


3 


4 


5 


6 


7 


8 


9 


10 11 


12 


13 


14 15 


LD FLAGS 























GROUP 








0P# 



LONG-DISTANCE 
FLAGS 



BITS 1 0, 1 1 , 1 2 & 1 5 
ENCODE FIRST WORD 
OF TWO-WORD OPCODE 



Bits 0, 1 and 2 of WR3 are initialized to the value of the 991 10's long-distance flags upon entry to Macrostore. These flags 
indicate whether an LDS or LDD instruction is currently in effect, as explained in Section 10. 
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TABLE 8-INSTRUCTIONS WITH TWO-WORD OPCODES 



MNEMONIC 


FIRST INSTRUCTION WORD 


Group 1: TMB 











1 


1 











1 





1 




TCMB 











1 


1 











1 


1 







TSMB 











1 


1 











1 


1 


1 




Group 2: AM 




















1 





1 


1 







SM 




















1 





1 





1 




Group 3: SLAM 























1 


1 1 





1 




SRAM 























1 


1 1 










Bits 10 and 1 1 identify gro 
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7.3.2 Exit Procedure 

Macrostore is generally exited by executing a RTWP instruction (opcode >0380). Interrupts are sampled prior to 
executing the next instruction. In those instances where interrupts (maskable or non-maskable) should not be 
sampled before executing the next instruction, the exit from Macrostore is invoked using the opcode >0384, a 
special form of the RTWP instruction. In either case, the WP, PC, and ST registers are updated with WRl 3, WR1 4, 
and WRl 5 from the MRAM. The >0384 exit ties the Macrostore operation to the execution of the instruction 
that follows the MID instruction. For example, it is used in emulating the LDD and LDS instructions, described in 
Section 10. 

If the Macrostore is entered upon detection of a MID opcode, and the emulation software in Macrostore deter- 
mines that it does not recognize the MID opcode as valid, the software must transfer control to the level-2 inter- 
rupt service routine, which has the responsibility for dealing with illegal opcodes. The emulation software in 
Macrostore uses the opcode >0382, another special form of the RTWP instruction, to exit the Macrostore under 
these conditions. When this opcode is executed in Macrostore, the processor sets the ILLOP flag of the error 
status bits (Section 4.4) before executing the RTWP operation. Consequently, following the context switch back 
to the program in main memory that contains the undefined opcode, the ILLOP flag forces a trap to the level-2 in- 
terrupt service routine. The ILLOP interrupt is non-maskable and cannot be disabled by the interrupt mask in ST1 2- 
ST15. 

The opcodes >0380, >0382 and >0384 provide the only means for performing an exit from Macrostore. To 
perform an RTWP in Macrostore (i.e., inverse of a BLWP) the opcode >0381 should be used. This opcode will 
allow for return branching in the Macrostore address space without exiting Macrostore. 

7.3.3 Macrostore Execution 

During Macrostore execution, several processor functions are modified to provide increased control. These are described 
below. 

7.3.3.1 Status Register 

The contents of the status register are not affected by the context switch to Macrostore that follows detection of a MID 
opcode. Macrostore routines are "super-privileged," meaning that they can alter the contents of the status register and 
perform other privileged operations regardless of the value of the privileged mode flag, ST7. An ST bus status code (Table 
2) is output from the processor when a Macrostore routine alters the ST register by means of the LST instruction. When 
the status register of the original main memory program environment must be modified, the appropriate bits of WR 1 5 must 
be modified prior to Macrostore exit. 

During emulation of an MID opcode in Macrostore, the emulation routine can modify the ST register value saved in WR 15 
in accordance with the results. During the context switch that follows the exit from Macrostore, the new status is loaded 
into the ST register. If the status value saved in WR15 has not been changed since the entry to Macrostore, it will be 
restored in its original form. 

While in Macrostore, the setting of both ST4 and ST10 to 1 does not cause the AF flag of the error status register to be 
set to 1 . If an arithmetic fault interrupt is to be generated, then bit 4 and 10 of WR 1 5 should be set so that an arithmetic 
fault trap will occur when the context switch out of Macrostore is made. 
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If it is required to modify the status bits of the main memory routine's status register prior to context switching out 
of Macrostore, the appropriate bits of WR1 5 should be modified. (Note if ST7 = 1 , then status bits 6 to 1 5 will be 
set according to Section 6.) 



7.3.3.2 Interrupts 



All interrupts except RESET are inhibited while executing from Macrostore. However, pending interrupts can be 
detected using the conditional jumps described in Section 7.2.7.5. 

7.3.3.3 Macrostore Workspace Registers 

When Macrostore is initially entered, the Workspace Pointer is set to zero so that the internal Macrostore RAM is utilized as 
the workspace. The Workspace Pointer may be set to another value by the LWP, LWPI, or BLWP instruction when it is 
desired that the workspace be located in external Macrostore RAM. 

The workspace registers located in internal RAM have special uses associated with the evaluate address (EVAD) 
instruction described in Section 7.3.3.5. For this reason care must be exercised in assuring that the EVAD instruc- 
tion is used only with the Workspace Pointer equal to zero. 

Table 9 lists the dedicated functions of the workspace registers when the workspace pointer bits 11 to 1 5 are 
equal to zero as is the case when Macrostore is first entered. Table 1 lists the bus status codes of the workspace 
registers when the workspace pointer bits 11 to 1 5 are not equal to zero (i.e., external RAM is used). 



TABLE 9 - DEDICATED MRAM REGISTER FUNCTIONS 
[WP bits 11 to 1 5 are all zero] 



REGISTER 


MAIN 
MEMORY 
ACCESS 


BUS 

STATUS 

CODE 


MOD 

BY 
EVAD 


MOD 

BY 

MACRO 


USAGE 





NO 


AUMS 






shift counts 


1 


NO 


AUMS 








2 


YES 


lAQ 








3 


YES 


GM 




YES 


first word of 2-word opcode; * 
LDD and LDS internal flags 


4 


NO 


AUMS 






scratch register for EVAD * 


5 


NO 


AUMS 




YES 


one-word opcode or second * 
word of two-word opcode 


6 


YES 


SOP 








7 


YES 


OOP 


YES 




TdnotO 


EVAD* 
destination 
address 


WS 


Td = 


8 


YES 


SOP 


YES 




TsnotO 


EVAD* 

source 

address 


WS 


Ts = 


9 


YES 


WS 


YES 




EVAD address of external * 
dest. register if "R + 


A 


YES 


WS 


YES 




EVAD address of external * 
source register if "R -i- 


B 


NO 


AUMS 






BLandXOP 


C 


YES 


OOP 






CPU base address 


D 


YES 


WS 




YES 


oldWP 


E 


YES 


lOP 




YES 


okJPC 


F 


NO 


AUMS 




YES 


oWST 



'EVAD should only be used if the WP = 000O. 
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TABLE 10 - BUS STATUS CODE ASSOCIATED WrTH WP VALUE 
[WP bits 11 to 1 5 not equal to zero] 



REGISTER 
ADDRESS 

BITS 11 TO 15 


MAIN 
MEMORY 
ACCESS 


BUS 

STATUS 

CODE 





NO 


AUMS 


2 


NO 


AUMS 


4 


YES 


lAQ 


6 


YES 


GM 


8 


NO 


AUMS 


A 


NO 


AUMS 


C 


YES 


SOP 


E 


YES 


DOP 


WS 


10 


YES 


SOP 


WS 


12 


YES 


WS 


14 


YES 


WS 


16 


NO 


AUMS 


18 


YES 


DOP 


1A 


YES 


WS 


1C 


YES 


lOP 


IE 


NO 


AUMS 



7. 3. 3. 4 Accessing Main Memory 

During Macrostore execution, data in the main memory is accessed using the indirect autoincrement and indexed 
addressing modes (*R, *R + and @TABLE(R)). MRAM workspace registers 2, 3, 6, 7, 8, 9, 10, 12, 13 and 14 are used as 
base registers during these accesses. This is only true when the Workspace Pointer resides on a 32-byte boundary, i.e. , five 
LSB's = 0. When a routine residing in Macrostore accesses the main memory through one of these registers, the acce^ is 
accompanied by a bus status code indicating a particular type of memory cycle, and MEM is held active-low. The bus 
staftis code corresponding to the use of each register is indicated in Table 9 for the case when WP = > 0000. When the WP 
does not equal zero, the type of bus cycle and corresponding bus status code is determined by the least-significant 
addresses of the workspace register as shown in Table 10. For simplicity, it is recommended that the Workspace Pointer 
point to a 32-byte boundary to avoid confusion as to the typ>e of bus cycle that will occur when the register is used as base 
register for memory transfers. Each main memory access shoukl utilize a base register whose use is accompanied by the 
bus status code appropriate to the type of ac(»ss being perfornned. 

As shown in Table 9, WRs 7 and 8 are a special case in regard to the bus status code output during a main memory access. 
The default bus status code output by the processor is DOP (Table 2) when WR7 is used to access main memory; the 
default for WR8 is SOP. If an EVAD operation (to be described) is performed on an opcode whose Td field is (workspace 
register direct addressing), the bus status code associated with WR7 is changed from its default of DOP to WS . Similarly, if 
an EVAD op>eration is performed on an opcode whose Ts field is 0, the bus status code for WR8 is changed from SOP to 
WS. If an EVAD subsequently is performed on an instruction with non-zero Td, the default of DOP is restored to WR7, 
and a non-zero Ts restores SOP to WR8. Everytime Macrostore is entered, the default status codes are restored. 

Two examples illustrate the main memory access capability. The convention is to refer to the program in main memory that 
contains the MID opcode as the "user's" program. Assume that WR13 in MRAM contains the user's Workspace Pointer. 
To read the contents of WR4 in the user's workspace into WR1 in MRAM, the instruction MOV @8(R1 3), R1 is 
executed from Macrostore. A WS bus status code is output during this operation (MEM = 0, BST = 110), 
Second, assume that WR1 4 in MRAM contains the user's PC value. To read immediate data or a symbolic address 
(following a MID opcode in the user's program) into WR14 in MRAM, the instruction MOV •R14 + ,R1 is ex- 
ecuted. This also causes the user's PC value in WR14 to be incremented by two, and an lOP bus status code is 
output (MEM = 0, BST = 010). 
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Using register 0, 1 , 4, 5, 1 1 or 1 5 as base register for indirect autoincrement or indexed addressing results, in an 
access of Macrostore. During l\^acrostore accesses, the AUiS^S and AUMSL bus status codes are output to 
distinguisli them from accesses of the main memory. 

While executing in Macrostore, all symbolic addresses refer to locations within Macrostore. A I/O access using the base 
address in Macrostore register WR12 is accompanied by the I/O bus status code. 

7.3.3.5 Evaluate Address Instruction— EVAD 

An EVAD instruction during Macrostore execution permits convenient calculation of effective source and destination 
addre^es for MID opcodes. EVAD assumes that the MID opcode contains a six-bit source operand field, and a six-bit 
destination operand field, i.e., the dual-operand format described in Section 10.5.1. The address calculations are based 
upon the original WP of the user, saved in WR13 in MR AM. Note that the EVAD instruction assumes that the WP is equal 
to zero as initialized upon entry into Macrostore. If the WP is modified to point to external MRAM, the WP must be 
restored to zero prior to EVAD execution. If the contents of a register in the user's workspace are fetched as part of the 
address calculation, a WS bus status code is output by the processor white the extemal access takes place. The saved PC 
(in WR14) is Incremented appropriately if symbolic or indexed addressing is used. The contents of any workspace register 
in MRAM except WRO can be evaluated using EVAD. When EVAD is executed, the calculated effective source address is 
placed in WR8 in MRAM, and the calculated destination address in WR7. If the source or destination fiekl specifies 
autoincrement mode, the address of the user's register is placed in WR9 or WR10, respectively. Executk>n of EVAD alters 
the contents of WR4, which EVAD uses as a scratch register. A summary of the EVAD instruction, including its effect on 
status bits and 2, is presented in Table 1 1 . 



Instruction 

Format 
For EVAD: 



10 11 12 



15 



0000000100 


Ts 


8 



opcode 



mode 



The Ts and S fields above are used to determine the effective source address of the target word of the EVAD in- 
struction. Once the target word is fetched as the source operand, the Ts, S, Td and D fields from that word are ex- 
tracted and utilized as indicated below. 



TABLE 1 1 - EVALUATE ADDRESS INSTRUCTION 



STATUS 

BITS 
AFFECTED 


DESCRIPTION 


0^ST2 
1 -STO 


DA -* WR7 
SA — WR8 

If target Ts = (symbolic or indexed) 
WR14 + 2-WR14 

If target Td = 2 (symbolic or indexed) 
WR14 + 2-WR14 

If target Ts not 3 
If target Td not 3 


1 -ST2 


If target Ts = 3 (autoincrement): 
address of external register -► WR10 


0-*STO 


If target Td = 3 (autoincrement): 
address of extemal register -* WR9 



The processor's WP register must be set to >0000 before executing the EVAD instruction. Otherwise, the results are 
unpredictable. 

If only the source field of an MID opcode is to be evaluated, the Td field (bits 4 and 5) should be cleared to prevent 
unnecessary external accesses or unintentional modification of WR1 3 (generally the user's PC). For example, if 
the MID opcode resides in WR5 and bits 4 and 5 are not zero in MRAM, the instruction sequence 
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ANDIR5,>F3FF 

EVAD R5 
is executed while in Macrostore to calculate the effective source address. The destination field, which is all zeros, is 
interpreted as register direct addressing mode (and STO is set to one). In order to deal with the case where the source field 
specifies autoincrement mode (ST2 = 1 ), the instructions above are followed by 

JEQ$+4 
INCT •R10 
The second instruction increments the user's base register by two, assuming the source operand is one word in length. If 
the operand occupies a byte or double-word instead, the base register should be incremented by one or four, respec- 
tively.* 

When developing an effective address based upon one of the user's workspace registers (in main memory), the EVAD 
instruction uses the contents of Macrostore register WR13. When developing an operand address based upon the user's 
program counter, the EVAD instruction uses the contents of Macrostore WR 1 4. Note that WR 1 4 is incremented by two for 
each symbolic or indexed addressing mode utilized. 

7. 3. 3. 6 Jump on Interrupt Status 

The TB (test bit), SBO (set bit to one) and SBZ (set bit to zero) instructions are not available during Macrostore execution. 
In place of these operations and using the same opcodes are conditional jump instructions that detect pending interrupts. 
A "pending" interrupt is defined as an interrupt that has been requested by activating the processor's NMI, or by asserting 
a request for an external interrupt that is not disabled by the interrupt mask in ST12-ST15. The instructions described in 
Table 12 allow interrupts to be tested at interruptible points in Macrostore routines. With this capability, instructions 
requiring long execution times can be emulated in a way that permits them to be interrupted and resumed after interrupt 
servicing. 

The "jump if interrupt present" can be used to test for the occurrence of an interrupt. 

The "jump not equal and no interrupt present" is useful in testing for interrupts while in loops. This single instruc- 
tion may be used to exit a loop either on the condition that the loop count is zero or the interrupt is present. ^ 



EXAMPLE: 



LOOP MOV •R1-l-,*R2 + 

DEC R3 
SBZ LOOP 
JNE OUT 



R3 HAS LOOP COUNT 

DONE? 

JUMP TO OUT IF NO INTERRUPT 



OUT 

These jump instructions have a displacement range of - 128to + 127 words from the memory- word address following the 
jump instruction . The displacement is specified in the odd byte of each instruction. No status bits are affected by execution 
of a jump instruction. 

The SBO and SBZ opcodes are executed in Macrostore as conditional jump instructions. SBO is equivalent to "jump if an 
interrupt is pending," and SBZ is equivalent to "jump if an interrupt is pending and ST2 is zero." The TB opcode is 

undefined in Macrostore. These instructions are summarized in Table 12. 

TABLE 12- JUMP ON PENDING INTERRUPT 



MNEMONIC 


OPCODE 


MEANING 


SBO 


1DXX 


Jump if unmasked interrupt is present 


SBZ 


1EXX 


Jump if equal bit is not set and unmasked Interrupt is not 
present 


TB 


1FXX 


Undefined 



* The incrementing of workspace registers in the main memory is not performed by the EVAD Instruction but is the responsibility of the Macrostore software. 
Care may therefore be required to deal with the instance where the target word of an EVAD operation contains source and destination fields that specify in- 
direct autoincrement using the same workspace register n (i.e., *Rn + , *Rn + ). Otherwise, both the source and destination operands (pointed to by register 
n) will be read from the same address rather than from successive addresses. 

^ When using SBZ to check for exiting a loop, a JNE or JEQ instruction should follow (outside the loop) to determine the reason the loop was exited; SBO should not be 
used for this purpose when an interrupt is applied and then removed. 
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7.3.4 Subroutine Branch and Return 

While executing in Macrostore, the BLWP instruction can be used to transfer program control to a subroutine located 
within Macrostore. For this purpose the opcode >0381 should be used. This version of the RTWP opcode should be 
distinguished from the RTWP variants >0380, >0382 and >0384, discussed in Section 7.2.6, all three of which cause an 
exit from Macrostore. 

7.3.5 MID Opcodes in Interrupt Routines 

One restriction exists regarding the use of MID opcodes within interrupt service routines. An MID opcode encountered in 
the interrupt routine for an NMI or level-1 interrupt, or for a Reset routine that does not cause complete system reinitializa- 
tion, must not result in an exit from Macrostore by means of opcode >0382, the special form of RTWP that causes a !eve!-2 
trap. The reason is that the level-2 routine can be interrupted by an NMI, level-1 interrupt or R^et, possibly destroying the 
return linkage established previously. In general, this restriction can be interpreted to mean that a MID opcode in the 
service routine of an interrupt of higher priority than level 2 must either be recognized by an attached processor or defined 
by an emulation routine in Macrostore. 

7.3.6 Testing for External Macrostore 

The on-chip Macrostore software can use the following technique to allow the user to optionally expand the Macrostore 
functions by adding new routines residing in off-chip RAM or ROM. The TMS99110 uses this technique to check for 
populated off -chip Macrostore memory. 

When the emulation software in the 991 10's on-chip MROM determines that it cannot execute a particular MID opcode, it 
then checks to determine whether the system contains external Macrostore (off -chip RAM or ROM ) . If so, the Macrostore 
program branches to location >1002, the entry point of the emulation software in the external Macrostore. Otherwise, a 
level-2 interrupt is requested, as described in Section 7.2.4.1 . 

The check to determine whether the system contains external Macrostore works as follows. In a system having external 
Macrostore, the code > AAAA (alternative ones and zeros) must be stored at Macrostore address >10(X), which is the first 
location in the off-chip region of Macrostore. The internal Macrostore emulation software upon deciding to test for 
external Macrostore, reads the contents of address >1000. If this location contains the code > AAAA, this confirms that 
the extemal Macrostore is present. 

8. ATTACHED PROCESSOR (AP) INTERFACE 

The TMS99000's bask: instruction set can be extended by defining new instructions. The extended instruction set is 
supported either by emulation software contained in external Macrostore, or by external hardware utilizing the 
TMS99(XX)'s attached processor (AP) interface. The TMS99000's AP interface provides complete software transparency 
between these two methods. System support for extended instructions can be conveniently upgraded from Macrostore 
emulation routines to attached processors without affecting the user's software base. 

An AP in a TMS99(X)0 system attaches to the local bus of the microprocessor. While the processor is actively executing 
instructions, the AP passively monitors the bus to detect opcode fetches. The TMS99000 outputs an lAQ (instruction 
acquisition) bus status code to notify the AP each time an opcode fetch cycle occurs, and the AP latches the opcode from 
the bus to examine it. When the TMS99000 fetches an opcode which it does not recognize, but which the AP is prepared to 
execute, the TMS99000 transfers control of the local bus to the AP. After the AP completes execution of the instruction, it 
returns control to the processor. 

The signals utilized by the AP interface of the TMS99000 are shown in Figure 29. The transfer of control from the 
TMS99000 to an AP and the eventual return of control to the TMS99000 takes place chiefly through the following three 
signals: 

• APP (attached processor present) input 

• MID (macro-instruction detected) bus status code 

• HOLDA (hold acknowledge) bus status code 
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TMS99000 



c 



MEM 



ADDRESS/DATA (0-15) 



•-♦ 



ALATCH 



WE/CRUCLK 



RD 



READY 



R/W 



APP 



BST{1-3) 



\i w 



-> 



<^ 



MEMORY 
SYSTEM 



ATTACHED 
PROCESSOR 



FIGURE 29- ATTACHED PROCESSOR INTERFACE 



System memory, shared by the TMS99000 and the AP, is used to transfer context information from one to the other. The 
TMS99000's workspace registers, which reside in memory, are readily available to the AP while the AP remains in control 
of the local bus. 

The timing for the AP interface is shown in Figures 30A and 30B. When the TMS99000 fetches an opcode it does not 
recognize, it outputs an MID bus status code to notify APs, should they be present, that it is prepared to relinquish system 
control. An opcode that causes this to occur will be referred to as an MID opcode. A list of MID opcodes is presented in 
Section 10.5.17. If bit 11 of the status register is set to 1, an XOP will also be treated as an MID opcode. 
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CLKOUT 



ALATCH 




BST(1-3) " y lAQ Y (1) XAUMSVI^ 
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MEM "\ 



READY 



(2) 



^ 



(4) 
hi-z 



APP 



vvvwwvwv\^^^\^ 



R/W 



X 



I INSTR I LAST I 
I FETCH I STATE I 



I OF 
I MID 
I OP- 
I CODE 
I 



I OF 
i PRIOR I 
I INSTR I 
I I 

I I 



DETERMINE 
IF ATTACHED 
PROCESSOR 
IS PRESENT 



(6) 



V- ^ V- 



FETCH NEW 
WP; STORE 
OLD PC, WP 
AND ST 



HOLD STATE 



I AP CYCLES: 
ALL CONTROL 
LINES ARE 
DRIVEN BY 
ATTACHED 
PROCESSOR 



NOTES: 

(1 ) This bus status is determined by the prior instruction. 

(2) Processor will reniain in this state until READY goes high. 

(3) BST = ST when the new status is output 

= INTA when the new WP is fetched 
= WP when the new WP is output 
= WS while the old WP, PC, and ST are stored 
(For simplicity, AUMS bus status codes are not shown.) 

(4) The processors tristates all signals except ALATCH as follows: 

• BST1 -BST3 are first driven high to indicate hold acknowledge and then are tristated. 

• MEM, RD and WE are first driven high and then tristated. 

• The address-data bus Is tristated "as is". 

(5) The processor first drives its ALATCH output high and then tristates it. 

(6) The CLKOUT remains the system clock throughout. 

FIGURE 30- AP INTERFACE TIMING 
(A) Transferring Control to Attached Processor 
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CLKOUT 



ALATCH 




APP 



r 



HOLD 



J 14) 



LAST 
STATE 
OFAP 
CON- 
TROL 



APP 

RELEASED; 
AP AND MAIN 
CPU BOTH 
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PROCESSOR i 
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PUT 
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ST 



! FETCH I OUT- 



NEXT 
INSTR 



PUT 
NEW 
WP 
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I 



NOTES: 

( 1 ) The AP tristates aN signals except ALATCH as foNows: 

■ BST- 1-BST-3 are first driven active high and then are trtetated. 
, MEM, RO and WE are first driven high and then are tristated. 
• The addre%-data lines are tristated. 

(2) The AP drives its ALATCH high and then tristates it. 

(3) BST = WS during WP. PC, and ST fetches. 

(4) An AP that fetches instructions for chained operations wHI assert HOLD and retoase APP during the instruction fetch to allow APP to be used for a breakpomt 

request. 

FIGURE 30 - AP INTERFACE TIMING 
(B) Regaining Control From Attached Processor 

Assuming that an A P is ( 1 ) present and is (2) prepared to execute the MID opco de, it responds to the MID bus status code 
by pulling the APP line low to signify its readiness. Upon detecting the APP signal, the proc essor p repares to transfer 
control to the AP. This involves clearing status bit 8 and performing a context change. With the PSEL output signal high, 
the processor fetches the new WP value from the trap vector for the level 2 interrupt. (The PC value from the vector is not 
fetched.) The old WP, PC and ST values are saved in WRs 13, 14and 15 of the new workspace. The saved PC points to the 
word following the MID opcode. After completing these actions, the processor begins a hold cycle, forces its outputs to 
the high-impedance state, and asserts HOLDA. This is the processor's signal that it is ready for the AP to assume control of 
the local bus. 

Sin ce the 99000 uses the same HOLDA bus status cod e to respond to both DMA devices and AP s, each AP must monitor 
the HOLD line to distinguish a HOLDA in response to APP from a HOLDA in response to HOLD. 

After taking control of the local bus, the AP begins executing the operation specified by the MID opcode. If a multiple- 
word instruction format is specified, the PC value saved in WR14 is used by the AP to access immediate data and operand 
address information. The contents of the original workspace are accessed through the WP value saved in WR13. The ST 
value in WR15 is altered to reflect the results of the operation performed. 

The 990 00 co ntinually samples its APP and HOLD inputs during the hold cycle. When the AP completes its operation and 
releases APP, the processor responds by terminating the hold cycle . The processor loads PC, WP and ST registers with the 
values in WRs 13, 14and 15, and resumes execution. 
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If an MID opcode is detected and APP remains high, indicating that no AP is prepared to execute the instruction, the 
processor perfomns a context switch that transfers control to the instruction emulation software contained in its Macros- 
tore (Section 7). 

The APP input performs a second function apart from its use in trans ferrin g control to an AP. An external device 
can use APP to force the processor to enter a hold cycle by asserti ng A PP during the instruction acquisition (lAQ) 
cycle. The mechanism works as follows. The processor samples APP at the end of every opcode fetch, at the 
same point that it latches the opcode. The processor fetches the WP value from the level 2 trap vector and saves 
the old WP, PC, and ST values in WRs 13,14, and 1 5 of the new workspace. The PC value saved in WR1 4 points 
to the memory word containing the opcode that was just fetched (and discarded}. Follow ing t he context switch, 
the processor outputs the HOLDA bus status code, enters the hold state, and waits for APP to be released, as 
before. 

The APP signal can be used by a mainten ance panel to force the processor to enter hold. Using the mechanism described 
above, the maintenance panel can trigger APP on either a selected address or a sele cted opcode to cause a breakpoint. To 
avoid possible interference with APs, the maintenance p anel s hould not assert APP during an MID bus sta tus c ode if it was 
not active at lAQ. If the "panel option" is used with APP, an attached processor should not assert APP until it has 
recognized a MID bus status code. 

The processor acknowledges an unmasked inten^upt upon completing execution of the instruction during which the 
interrupt becomes active. If the processor must respond to an intenupt before it can begin execution of a prefetched 
opcode,* the opcode is discarded prior to trapping to the interrupt service routine. Upon return from the interrupt, the 
opcode prevHjusly discarded is again fetched from memory. A special case of this procedure occurs when the discarded 
opcode is an MID opcode that an AP is preparing to execute. The AP must discard the opcode also. The AP knows to 
discard the opcode if the processor, following its fetch of the MID opcode, outputs the INTA bus status code. 
Alternatively to checking for the INTA bus status code, the AP can check for a subsequent lAQ bus status code in- 
dicating that the instruction has been discarded. This means that the processor has discarded the opcode in order 
to service the pending interrupt. 



APs must monitor HOLD to detect DMA requests as discussed above. In a processor system containing one or more APs, 
the TMS99000 HOLDA signal is not distributed directly to DMA devices but is gated with the hold acknowledge signals 
from the APs to forni a composite hoW acknowledge signal that is passed on to the DMA devices. This composite hold 
acknowledge signal, which signifies transfer of control to the DMA device, is generated only after the processor and all 
APs have entered the hold state. 

When an X (execute) instruction is executed, an lAQ bus status code is iSIOT output during the fetch of the target opcode 
located at the effective source address of the X instruction. Instead, an SOP or WS bus status code is output, depending 
on the addressing mode used. This means that APs cannot rely upon the lAQ bus status code to notify them when the 
processor fetches a MID opcode that is the target opcode of an X instruction. 

The AP interface can be disabled by tying APP to ground. When operating in this mode, the processor automatically 
generates an ILLOP inten-upt request upon encountering an MID opcode, bypassing the AP interface and Macrostore. 

*The processor routinely prefetches the next opcode one state prior to completion of the current instruction (Section 10.6.2). 
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PIN DESCRIPTION 

Table 13 defines the TMS99105A/TMS991 10A pin assignments and describes the functions of each pin. 
Figure 31 illustrates the TMS99105A/TMS991 10A pin assignment information. 
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FIGURE 31 - PIN ASSIGNMENTS 
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TABLE 13- PIN DESCRIPTION 



SIGNATURE 


PIN 


I/O 


DESCRIPTION 


POWER SUPPLIES 


v'cc 


15 




Supply voltage: -t- 5 V nominal. 


Vss 


6,33 




Ground reference. 


CLOCKS 


XTAL1/CLKIN 


36 


IN 


Crystal input pin for internal oscillator; also input pin for external oscillator. 


XTAL2 


36 


IN 


Crystal input pin for internal oscillator. 


CLKOUT 


34 


OUT 


Clock output signal. The frequency of CLKOUT is Y* the frequency of the crystal oscillator. 


ADDRESS/DATA BUS 


AO/DO/IN 


16 


I/O 


While ALATCH = 1 , these lines function as an address bus consisting of output signals A0-A14 and PSEL. 


(addr/data MSB) 






During memory, I/O and Macrostore accesses, an address is output on A0-A14. During memory cycles. 


A1/D1 


17 


I/O 


status bit 8 is output in complemented form on PSEL; PSEL is forced high during I/O accesses. During WP 


A2/D2 


18 


I/O 


and ST bus cycles (Table 2), status infonnation is output on the address bus. 


A3/D3 


19 


I/O 


While ALATCH = 0, these lines function as a bidirectional data bus for memory, I/O and Macrostore 


A4/D4 


20 


I/O 


accesses. During a bit-parallel byte or word read operation, (RD active low), data is input on D0-D15. 


A5/D5 


21 


I/O 


During a bit-parallel write operation (WE/IOCLK active low), data is output on D0-D15. For bit-serial I/O 


A6/D6 


22 


I/O 


operations, read data is input on IN, and write data is output on OUT. 


A7/D7 


23 


I/O 


These lines are forced to the high-impedance state during a hold cycle. 


A8/D8 


24 


I/O 




Ad/D9 


25 


I/O 




A10/D10 


26 


I/O 




All /Oil 


27 


I/O 




A12/D12 


28 


I/O 




A13/D13 


29 


I/O 




A14/D14<addrLSB) 


30 


I/O 




PSEUD15/0UT 


31 


I/O 




LOCAL BUS CONTROL SIGNALS | 


ALATCH 


32 


OUT 


Address latch. While ALATCH is high, the multiplexed address-data lines function as an address bus; while 
ALATCH is low, they function as a data bus. Each bus cycle (memory, I/O or internal) begins with a 
positive ALATCH pulse, the falling edge of which is used by extemal logic to latch the contents of the 
address bus. The MEM and BST1-BST3 outputs are stable while ALATCH is low. 
Prior to entering hold, the HOLDA bus status code is output and the ALATCH signal undergoes one final 
high-to-low transition before being driven to the high-impedance state. This permits an extemal device to 
latch the HOLDA code. 


MEM 


40 


OUT 


Memory cycle. When low, MEM indicates that a memory cycle is in progress. When high, MEM indicates 
that a I/O or intemal cycle is in progress. MEM is forced to the high-impedance state during a hold cycle; an 




1 


OUT 


internal resistive pull-up maintains a high level. 


WE/IOCLK 


Write enable and inverted I/O clock. When low, WE/IOCLK indicates that write data is present on 


the data bus. WE/IOCLK is active during memory writes (MEM = 0), serial I/O writes (MEM = 1, 








BST2 = 1, A0=0). parallel I/O writes (MEM = 1, BST2 = 1, A0 = 1), and writes to extemal 


Macrostore (MEM = 1 , BST2 =0). WE/IOCLK is a tri-state output signal, and is forced to the high- 








impedance state during a hokl state; an internal resistive pull-up maintains a high level. 


RD 


2 


OUT 


Read Enable. When active low, RD indicates that a read (memory, parallel I/O, serial I/O or extemal 
Macrostore) is taking place on the bus, and that external devices may enable their tristate drivers to gate 
data onto the address-data lines. RD is a tristate signal and is forced to the high-impedance state during a 








hokJ state; an intemal resistive pull-up maintains a high level. 


R/W 


14 


OUT 


READ/WRITE. The R/W is valid at the beginning of each new cycle. This signal is high during read 
operation and knw during write operations and internal ALU cycles. When R/W is low, it indicates that the 
99000 will be driving the data bus. When R/W is high, it indicates that the 99000 will tristate the data bus 








(AD bus during the data time). 
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TABLE 13- PIN DESCRIPTION (CONTINUED) 



SIGNATURE 


PIN 


I/O 


DESCRIPTION 


LOCAL BUS CONTROL SIGNALS (CONCLUDED) J 


READY 


7 


IN 


Ready. When high, READY indicates that the current bus cycle (memory, I/O or internal) is ready to be 
completed. As long as READY remains low to indicate a not ready condition, the bus cycle continues to be 
extended with wait states. Near the end of each wait state, READY is sampled to determine whether the 
bus cycle can complete or another wait state is to be generated. Note that this READY function differs 
from some READY functions in that bus cycles of non-memory cycles are affected by its operation. 


INTERRUPTS 1 


INTREQ 

ICO (MSB) 

IC1 

IC2 

IC3(LSB) 

NMI 


8 

10 
11 
12 
13 
9 

3 


IN 

IN 
IN 
IN 
IN 
IN 

IN 


Interrupt request. When active low, INTREQ indicates that an external inten-upt is requested. If INTREQ is 
active, the processor latches the contents of the interrupt code inputs IC0-IC3 into its internal interrupt 
code register. The code is compared with the interrupt mask in status register bits 12-15. If the code is less 
than or equal to the mask value, the interrupt is granted; otherwise, the request is ignored. IC0-IC3 
continue to be sampled as long as INTREQ remains low. If the request is initially disabled by the mask, 
INTREQ may be held low until the mask changes to a value that enables the request. 


Interrupt code. ICO is the MSB of the 4-bit interrupt code. IC0-IC3 are sampled when INTREQ is active low. 
The highest-priority interrupt level is signified by IC0-IC3 = LLLL; the lowest level is HHHH. 

Non-maskable interrupt. When active low, NMI causes the processor to perform a non-maskable interrupt 
using the trap vector located at memory address FFFC. The NMI sequence begins following the execution 
of the instruction in progress at the time the NMI request is initiated. The NMI will also terminate an idle 
state. If NMI is active during the time RESET is released, the NMI sequence will occur following completion 
of the reset sequence, but prior to execution of the first instruction in the reset service routine. NMI must be 
active for at least one CLKOUT cycle to be recognized and will only be recognized once for each high-to- 
low transition. 


RESET 


RESET. When active low, RESET causes the processor to set all status bits to zero and inhibits WE/ 


lOCLK, RD and MEM internally. When RESET is released, the processor initiates a level inten^pt 
sequence using the trap vector at memory address 0000, clears the entire status register, and begins 
executing the reset service routine. RESET also will terminate an idle state. RESET must be heki active for 


at least three CLKOUT periods to guarantee that a Reset will take place. RESET is a Schmitt-trigger input. 


DMA REQUEST 


HOLD 


5 


IN 


HOLD. An external controller generates a hold request by pulling the processor's HOLD input low. This 
indicates the controller's wnsh to obtain control of the local bus to perform one or more DMA transfers. The 
processor responds to the hold request by outputting a HOLD A bus status code (Table 12) and 
then forcing MEM, WE/IOCLK, RD, BST1 -BST3, R/W, ALATCH and the address data lines to the 
high-impedance state. When HOLD is released, the processor terminates the hold cycle and 
resumes processing. 


BUS STATUS 


BST1 (MSB) 
BST2 
BST3 (LSB) 


39 
38 
37 


OUT 
OUT 
OUT 


Bus status lines. These lines are used with the MEM output to provide external circuitry with information 
concerning the nature of the bus cycle currently in progress. The bus status codes are presented in Table 2 . 
MPILCK is indicated by BST1-BST3 = 000. BST1-BST3 are forced to the high-impedance state during a 
hold cycle. 
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TABLE 13- PIN DESCRIPTION (CONCLUDED) 



SIGNATURE 


PIN 


I/O 


DESCRIPTION 


ATTACHED PROCESSOR 


Apr 


4 


IN 


Attached processor present. When the TMSSQOOO fetehesan MID opcode {Section 2.4), it outputs an MiD 
bus status code arui samples the APP input. If APP has been pulled low by an external device, the CPU 
perf omns a context switch and relinquishes control of the local bus. The CPU fetches the new WP from the 
level 2 trap vector, and the old WP, PC, and ST are saved in the new workspace. The CPU signals 
its release of the local bus by outputting a HOLD A bus status code and then enters hold. After the 
attached processor has completed its operation, it releases APP; the CPU responds by terminating, 
restoring its context, and resuming processing. 

If no external device asserts APP, the CPU attempts to emulate the MID opcode in Macrostore and traps to 
the level 2 interrupt service routine if the opcode is undefined in Macrostate. 
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10. 



INSTRUCTION SET 



4A •• r>v?d&ii^ir\ai 

■U.I Lrcriini I ■\^iv 

Each TMS99000 instruction perfomis one of the following: 

• Arithmetic or logical operation on data, or connparison or manipulation of data, 

• Loading or storing of internal registers (program counter, workspace pointer, or status register), 

• Data transfer between memory and extemal devices via the I/O, or 

• Control functions. 

10.2 ADDRESSING MODES 

The TMS99000 instruction set provides a variety of modes for addressing random memory data, e.g. , program parameters 
and flags, or formatted memory data (character strings, data lists, etc.). These addressing modes are: 

• Workspace register addressing 

• Workspace register indirect addressing 

• Workspace register indirect autoincrement addressing 

• Symbolic (direct) addressing 
. Indexed addressing 

• Immediate addressing 

• Program counter relative addressing 

• I/O relative addressing 

The derivation of the effective address for each addressing mode is described graphically betow. The applicability of each 
addressing mode to particular instructions is described in Section 10.5, along with the operation performed by each 
instruction. The symbols following the names of the addressing modes, R, "R, *R + , S)LABEL and @TABLE(R), are the 
general forms used by processor assemblers to specify the addressing mode for workspace register R. 

10.2.1 Workspace Register Addressing, R 



Workspace register R contains the operand. 
(PC) — 



REGISTER R 



INSTRUCTION ^{WP) + 2R-» OPERAND 



The workspace register addressing mode is specified by setting the two-bit T-field (Ts or Td) of the instruction word to 0. 
10.2.2 Workspace Register indirect Addressing, *R 

Workspace register R contains the address of the operand. 



REGISTER R 



(PO- 



INSTRUCTION -^(WP) + 2R-» ADDRESS 



OPERAND 



The workspace register indirect addressing mode is specified by setting the two bits in the T-field (Ts or Td of the 
instruction word to 1 . 

10.2.3 Workspace Register Indirect Autoincrement Addressing, *R + 

Workspace register R contains the address of the operand. After acquiring the address of the operand, the contents of the 
workspace register are incremented. 

REGISTER R 



INSTRUCTION 



y 



(WP) + 2R- 



OPERAND 




The workspace register indirect autoincrement addressing mode is specified by setting the two-bit T-field (Ts or Td) of the 
instruction word to 3. 
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10.2.4 Symbolic (Direct) Addressing, ©LABEL 

The word following the instruction contains the address of the operand. 



(PC)* 


INSTRUCTION 






iPC) + 2* 


LABEL 




OPERAND 





The symbolic addressing mode is specified by setting the two-bit T-field (Ts or Td) of the instruction word to 2 and setting 
the corresponding S or D field equal to 0. 

10.2.5 Indexed Addressing, €>TABLE(R) 

The word following the instruction contains the base address. Workspace register R contains the index value. The sum of 
the base address and the index value results in the effective address of the operand. 

REGISTER R 

••(WP) + 2R- 



(PC)-^ INSTRUCTION 



(PC) + 2-^ TABLE 



INDEX VALUE 


^A>^ EFFECTIVEj 






OPERAND 




V^ ADDRESS 



The indexed addressing mode is specified by setting the two-bit T-field {Ts or Td) of the instruction word to 2 and setting 
the corresponding S or D field to a value other than 0. The value in the S or D field is the number of the workspace register 
which contains the index value. 

10.2.6 Immediate Addressing 

The word following the instruction contains the operand. 



(PO- 
{PC)-i-2- 



INSTRUCTION 



OPERAND 



10.2.7 Program Counter Relative Addressing 

The 8-bit signed displacement in the right byte (bits 8 through 15) of the instruction is multiplied by 2 and added to the 
updated contents of the program counter. The result is placed in the PC. 

JUMP INSTRUCTION 

2*DISP 



PROGRAM COUNTER 



ADDRESS 



OPCODE 



DISP 



NEXT MEMORY WORD 



M 
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10.2.8 I/O Relative Addressing 



The 8-bit signed displacement in the right byte of the instruction is added to the I/O base address (bits through 
14 of workspace register 12). The result is the address of the selected bit in I/O space. 



(PC)- 



(WP) + 2*12- 



INSTRUCTION 



OPCODE 



DISP 



7 8 

REGISTER 12 



BASE 
ADD 



5 6 



15 



14 15 




CRU BIT 

► 

ADDRESS 



10.3 TERMS AND DEFINITIONS 

The terms used in describing the instructions of the processor are defined in Table 14. 

TABLE 14-SYMBOL CONVENTIONS 



SYMBOL 


DEFINITION 


B 
C 
D 
DA 


Byte indicator (1 = byte.O = word) 
Bit count 

Destination address register 
Destination address 


lOP 
LSB(n) 
MSB(n) 
N 


Immediate operand 
Least-significant (rightmost) bit of n 
Most-significant (leftmost) bit of n 
Don't care 


PC 

result 

S 

SA 

ST 


Program counter 

Result of operation performed by instruction 

Source address register 

Source address 

Status register 


STn 
Td 
Ts 
W 


Bit n of status register 
Destination address modifier 
Source address modifier 
Workspace register 


WRn 
(n) 
((n)) 
a— b 

|n| 


Workspace register n 
Contents of n 
Indirect contents of n 
A is transferred to b 
Ateolute value of n 


+ 

AND 
OR 


Arithmetic addition 
Arithmetic subtraction 
Logical AND 
Logical OR 


® 
"n 

• 


Logical exclusive OR 
Logical complement of n 
Arithmetic multiplication 


I/O base address 
effective I/O base address 

I/O bit address 


The address which is stored in WR12 

The address which is formed by adding the displacement to the base address In WR 1 2 for single 

bit I/O, or the incremented value of WR12 for multibit I/O. 

The effective address of a bit located in the lower half of the I/O space. 
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10.4 



STATUS REGISTER MANIPULATION 



Various TMS99000 machine instructions affect the status register. Figure 5 shows the status register bit assignments. 
Table 15 lists the instructions and their effect on the status register. 



TABLE 15 - STATUS REGISTER BIT DEFINITIONS* 



BIT 



STO 



NAME 



LOGICALLY 

GREATER 

THAN 



INSTRUCTION 



C,CB 



CI 



ABS, LDCR 



RTWP 



LST 



A, AB, Al 
AM, ANDi, 
DEC, DECT, 
LI, MOV, 
MOVB, NEG, 
ORI, S, SB, 
DIVS, MPYS, 
INC, INCT, 
INV, SLA, 
SLAM, SM, 
SOC, SOCB, 
SRA, SRAM, 
SRC, SRL, 
STCR, SZC, 
SZCB, XOR 



Reset 



All other 
instructions 
and 
interrupts 



CONDITIONS TO SET BIT T0 1 
(OTHERWISE SET TOO) 



If MSB(SA) = 1 and MSB(DA) = 0, or if 
MSB(SA) = MSB(DA) and MSB((DA) - (SA)) = 1 



If MSB(W) = 1 and MSB of lOP = 0, or if 
MSB(W) = MSB of lOP and MSB(I0P-(W)) = 1 



If (SA) is not zero 



lfblt0ofWR15is1 



If bit of selected WR is 1 



If result is not 
(see Note 2) 



STO is cleared unconditionally 



STO Is not affected 
(see Note 1 ) 



*See Table 13 for definition of tenninology used. 

NOTES: 1 . The X instruction itself does not set any status bits, but the target instruction may set status bits accordingly. 
2. If on a DIVS instruction an overflow occurs, ST4 is set and STO, ST1 , and ST2 are undefined. 
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TABLE 15 - STATUS REGISTER BIT DEFINITIONS (CONTINUED) 



BIT 


NAME 


INSTRUCTION 


CONDITIONS TO SET BIT T0 1 
(OTHERWISE SET TO OJ 


ST1 


ARITHMETIC 


COB 


If MSB(SA) = Oand MSB<DA)= 1, or if 




GREATER 
THAN 




MSB(SA) = MSB(DA) and MSBKDA) - (SA)) = 1 


CI 


If MSB( W) = and MSB of lOP = 1 , or If 








MSB{W) = MSB of lOP and MSBdOP - (W)) = 1 


ABS, LDCR 


If MSB{SA) = and (SA) is not 


RTWP 


lfbit1ofWR15is1 


LST 


If bit 1 of selected WR is 1 


A, AB, Al, 


If MSB of result = 0, 






AM,ANDI, 


and result is not 






DEC, DECT, 


(see Note 2) 






LI, MOV, 








MOVB, NEG, 








ORI, S, SB, 








DIVS, MPYS, 








INC, INCT, 








INV, SLA, 








SLAM, SM, 








SOC, SOCB, 








SRA, SRAM, 








SRC, SRL, 








STCR, SZC, 








SZCB, XOR 




Reset 


ST1 Is cleared unconditionally 


All other 


ST1 is not affected 






instructions 


(see Note 1 ) 






and 








inten-upts 





NOTES: 1 . The X instruction itself does not set any status bits, but the target instruction may set status bits accordingly. 
2. If on a DIVS instruction an overflow occurs, ST4 is set and STO, ST1 , and ST2 are undefined. 
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TABLE 15 - STATUS REGrSTER BIT DEFINITIONS (CONTINUED) 



BIT 


NAME 


INSTRUCTION 


CONDITIONS TO SET BIT T0 1 
(OTHERWISE SET TOO) 


ST2 


EQUAL/TB 
INDICATOR 


CCB 


lf(SA) = (DA) 


CI 


lf(W) = !OP 


COC 


If ((SA) and not (DA)) = 


czc 


If ((SA) and (DA)) = 


TB 


If CRUIN = 1 for addressed CRU bit 


TSMB, TCMB, 


If addressed memory bit = 1 








TMB 






ABS, LDCR 


lf(SA) = 


RTWP 


lfbit2ofWR15is1 


LST 


If bit 2 of selected WR is 1 


A, AB, Al, AM, 


If result = 








ANDI, DEC, 


(see Note 2) 








DECT, LI, 










MOV, MOVB, 










NEG,ORI, S, 










SB, DIVS, 










MPYS, INC, 










INCT, INV, 










SLA, SLAM, 










SM, SOC, 










SOCB, SRA, 










SRAM, SRC, 










SRL, STCR, 










SZC, SZCB, 










XOR 






Reset 


ST2 is cleared unconditionally 




All other 


ST2 is not affected 








instructions 


(see Note 1) 








and 










interrupts 






ST3 


CARRY OUT 


A, AB, ABS, 
Al, AM, DEC, 
DECT, INC, 
INCT 

NEG,S,SM, 
SB 


If carry out = 1 




SLA, SRA, 










SRL, SRC, 


If last bit shifted out = 1 








SRAM, SLAM 






RTWP 


lfbit3ofWR15is1 




LST 


If bit 3 of selected WR is 1 


Reset 


ST3 is cleared unconditionally 




All other 


ST3 is not affected 








instructions 


(see Note 1) 








and 










interrupts 







NOTES: 1 . The X instruction itself does not set any status bits, but the target instruction may set status bits accordingly. 
2. If on a DIVS instruction an overfiow occurs, ST4 is set and STO, ST1 , and ST2 are undefined. 
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TABLE 15 - STATUS REGISTER BIT DERNITIONS (CONTINUED] 



BIT 


NAME 


INSTRUCTION 


CONDITIONS TO SET BIT T0 1 
(OTHERWISE SET TOO) 


ST4 


ARITHMETIC 
FAULT 


A, AB, AM 


If MSB(SA) = MSB(DA) and 
MSB of result ^ MSB(OA) 


Al 


IfMSBCW) jt MSBoflOPand 
MSB of result jt MSB(W) 


S,SB,SM 


lfMSB(SA) = MSB(DA)and 
MSB of result = MSB(DA) 


DEC, DECT 


If MSB(SA) = 1 and MSB of result = 


INC, INCT 


If MSB(SA) = and MSB of result ^ 1 


SLA, SLAM 


If MSB changes during shift 


DIV 


lfMSB(SA) = 0andMSB<DA) = 1,orif 
MSB(SA) = MSB(OA) and MSB((DA) - (SA)) = 


DIVS 


If the quotient cannot be expressed 
as signed 16-bit quantity {>8000 
is a valid negative number) 


ABS, NEG 


If ISA) => 8000 


RTWP 


lfbit4ofWR15is1 


LST 


If bit 4 of selected WR is 1 


Reset 


ST4 is cleared unconditionally 


All other 
instructions 
and interrupts 


ST4 is not affected* 


ST5 


PARITY 
(ODD NO. 
0F"1" 
BITS) 


CB, MOVB 


If (SA) has odd number of ones 


LDCR 


IfC = 1 to 8 and (SA) has odd 
number of ones (if C = 9 to 15 
or C = 0, then STB is not affected) 


AB, SB, 
SOCB, S2CB, 


If result has odd number of ones 


STCR 


If C = 1 to 8 and the result has 
an odd number of ones (if C = or 
C = 9to 15, then ST5 not affected) 


RTWP 


lfbit5ofWR15is1 


LST 


If bit 5 of selected WR is 1 


Reset 


ST5 is cleared unconditionally 


Ail other 
instructions 
and 
interrupts 


STB is not affected 
(See Note 1) 



NOTES: 1 . The X instruction itself does not set any status bits 
2. If on a DIVS instruction an overflow occurs, ST4 is 



, but the target instruction may set status bits accordingly. 
set and STO, ST1 , and ST2 are undefined. 
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TABLE 15 - STATUS REGISTER BIT DEFINITIONS (CONTINUED) 



BIT 


NAME 


INSTRUCTION 


CONDITIONS TO SET BIT T0 1 
(OTHERWISE SET TO 0} 


ST6 


XOPiN 
PROGRESS 


XOP 


If XOP instruction is executed 
(ST6 set after the context switch) 


RTWP* 


If executed when ST7 = 1 
(non-privileged mode), 
then ST6 is cleared 


LST» 


If executed when ST7 = 1 
(non-privileged mode), 
then ST6 is cleared. 


Reset 


ST6 is cleared unconditionally 


All other 
instructions 
and 
interrupts 


ST6 is not affected 
(see Note 1 ) 


ST7 


PRIVILEGED 
MODE 


RTWP* 


lfbit7ofWR15is1 


LST* 


If bit 7 of selected WR is 1 


XOP, any 
interrupt 


ST7 is cleared unconditionally 


All other 
instructions 


ST7 is not affected 
(see Note 1) 


ST8 


MAP 
SELECT 


RTWP* 


lfbit8ofWR15is1 


LST* 


If bit 8 of selected WR is 1 


XOP, any 
Interrupt 


ST8 is cleared unconditionally 
prior to read of trap vector. 
Previous value is saved in WR15. 


LDCR, STCR, 
SBO, SBZ, 
TB 


ST8 temporarily driven to while 
CRU address is on the address bus 


All other 
instructions 


ST8 is not affected 
(see Note 1 ) 


ST9 


UNDEFINED 


RTWP* 


lfbit9ofWR15is1 


LST* 


If bit 9 of selected WR is 1 


XOP, any 
interrupt 


ST9 is cleared unconditionally 


All other 
interrupts 


Do not affect status bit 
(see Note 1) 


ST10 


ARITHMETIC 

FAULT 

INTERRUPT 

ENABLE 


RTWP* 


lfbit10ofWR15is1 


LST* 


Ifbit 1 0of selected WR is 1 


XOP, any 

interrupt 


ST10 is cleared unconditionally 


All other 
instructions 


ST10 is not affected 
(see Note 1 ) 



•Status bits 7, 8, 9, 1 1 , 12, 13 and 14 are not affected by LST or RTWP if ST7 = 1 before these instructions are executed. 
Note 1 . The X instruction itself does not set any status bits, but the target instruction may set status bits accordingly. 
2. If on a DIVS Instruction an overflow occurs, ST4 is set and STO, ST1 , and ST2 are undefined. 
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TABLE 15 - STATUS REGISTER BIT DEFINITIONS (CONCLUDED) 



BIT 


NAME 


INSTRUCTION 


CONDITIONS TO SET BIT T0 1 
(OTHERWISE SET TOO) 


ST11 


XOP 

EMULATION 

MODE 


RTWP* 


lfbit11ofWR15is1 


LST» 


If bit 11 of selected WR is 1 


XOP, any 
Interrupt 


ST1 1 is cleared uncondittonalty 


All other 
Instructions 


ST8 is not affected 


ST12 

to 

ST15 


INTERRUPT 
MASK 


LIMIt 


Set mask = bits 12-15of lOP 


RTWP* 


Set mask = bits 12-15 of WR15 


LST' 


Setmask = bits 12-15 of WR 


RSETt 
RESET, NMI 


Mask is unconditionally cleared 
(set to all zeros) 


All other 
interrupts 


If mask = 0, no change; 
otherwise, set mask to intemjpt 
level minus one. 


All other 
instructions 


Mask is not affected 
(see Note 1) 



Status bits 7, 8, 9, 1 1 , 1 2, 1 3, and 1 4 are not affected by LSI or RTWP if ST7 = 1 before these instructions are executed. 
^STI 2 to ST1 5 are not affected by LIMI and RSET if ST7 = 1 . 
NOTE 1 : The X instruction itself does not set any status bits, but the target instruction may set status bits accordingly. 

10.5 INSTRUCTIONS 

A list of the instructions described in each of the following subsections is presented below for convenient reference. 



Irwtructton Mnemonic 

A, AB, C, CB, S, SB, SOC, SOCB, SZC, SZCB, MOV, MOVB 
COC, CZC, XOR, MPY, DIV 

MPYS, DIVS 
XOP 

B, BL. BLWP, CLR, SETO, INV, NEG, ABS, SWPB, INC, INCT, DEC, DECT, X 
BIND 

LDCR, STCR 

SBO, SBZ, IB 

JEQ, JGT, JH, JHE, JL, JLE, JLT, JMP, JNC, JNE, JNO, JOC, JOP 

SLA, SRA, SRC, SRL 

Al, AND!, CI, LI, ORI, BLSK 

LWPI, LIMI 

STST, LST, STWP, LWP 

RTWP 

IDLE, RSET, CKOF, CKON, LREX 

TMB, TCMB, TSMB 

AM, SM, SLAM, SRAM 

MID opcodes 

LDD, LDS 

LR, STR, NR, CER, CIR, CRE, CRI, AR, DR, SR, MR 



SasSsB 

10.5.1 
10.5.2 
10.5,3 
10.5.4 
10.5.5 
10.5.6 
10.5.7 
10.5.8 
10.5.9 
10.5.10 
10.5.11 
10.5.12 
10.5.13 
10.5.14 
10.5.15 
10.5.16 
10.5.17 
10.5.18 
Appendix B 
Appendix B 
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10.5.1 Dual-Operand Instructions with Multiple Addressing for Source and Destination Operand 

General 
Format: 

If B = 1 , the operands are bytes and the effective operand addresses are byte addresses. If B = 0, the operands are words 
and the LSB of each effective operand address is ignored. 

The addressing mode for each operand is determined by the two bits of the T-field corresponding to that operand. 



2 


3 


4 5 


6 


7 8 


9 


10 11 


12 


13 14 


15 


OPCODE 


B 


Td 


D 


Ts 


S 



TsorTd 


SorD 


ADDRESSING MODE 


NOTES 





0,1, 15 


Workspace register 


1 


1 


0,1 15 


Workspace register indirect 




2 





Symbolic 


4 


2 


1,2 15 


Indexed 


2,4 


3 


0,1 15 


Workspace register indirect autoincrenfient 


3 



NOTES: 1 . When a workspace register is the operand of a byte instruction (bit 3 = 1 ), the left byte (bits through 7) is the operand and the right byte (bits 8 through 1 5) 
is not altered. 

2. Workspace register may not be used for indexing. 

3. The workspace register is incremented by 1 for byte instructions (bit 3 = 1 ) and is incremented by 2 for word instructkins (bit 3 = 0). 

4. When Ts = Td = 2, two words are required in addition to the instruction word. The first word Is the source operand and the second word is the destination 
operand base address. 











RESULT 






OPCODE 




COMPARED 


BITS 


STATUS 


MNEIMONIC 


0123 


MEANING 


TOO 


AFFECTED 


DESCRIPTION 


A 


1010 


Add 


Yes 


0-4 


(SA)-KDA)-^(DA) 


AB 


1011 


Add bytes 


Yes 


0-5 


(SA) + (DA)-(DA) 


C 


1000 


Compare 


No 


0-2 


Compare (SA) to (DA) and set ap- 
propriate status bits 


CB 


1001 


Compare bytes 


No 


0-2,5 


Compare (SA) to (DA) and set ap- 
propriate status bits 


S 


0110 


Subtract 


Yes 


0-4 


(DA)-(SA)^(DA) 


SB 


0111 


Subtract bytes 


Yes 


0-5 


{DA)-(SA)-(DA) 


see 


1110 


Set ones corresponding 


Yes 


0-2 


(DA) OR (SA) -(DA) 


SOCB 


1111 


Set ones corresponding bytes 


Yes 


0-2,5 


(DA) OR (SA)— (DA) 


SZC 


0100 


Set zeros corresponding 


Yes 


0-2 


(DA) AND (SA)— (DA) 


S2CB 


0101 


Set zeros corresponding 


Yes 


0-2,5 


(DA)AND(SA)— (DA) 


MOV 


1100 


Move 


Yes 


0-2 


(SA)-(DA) 


MOVB 


1101 


Move bvtes 


Y?s 


0-2,5 


i$A|-(DA) 



10.5.2 Dual-Operand Instructions with Multiple Addressing Modes for the Source Operand and Workspace Register 
Addressing for the Destination 

3 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 
OPCODE \ D I Ts I S I 



General 
Format: 



The addressing mode for the source operand is determined by the Ts field. 



Ts 


S 


ADDRESSING MODE 


NOTES 





0,1 15 


Workspace register 




1 


0,1 15 


Workspace register indirect 




2 





Symbolic 




2 


1,2 15 


Indexed 


1 


3 


1,2, ... ,15 


Workspace register indirect autoincrement 


2 



NOTES: 1. Workspace register may not be used for indexing. 
2. The workspace register is incremented by 2. 



65 









RESULT 


STATUS 






OPCODE 




COMPARED 


BITS 




MNEMONIC 


012346 


MEANING 


TOO 


AFFECTED 


DESCRIPTION 


coc 


001000 


Compare ones corresponding 


No 


2 


Test (D) to determine if Is are in 
each bit position wrhere Is are in 
<SA).lfso,setST2. 


czc 


001001 


Compare zeros corresponding 


No 


2 


Test (D) to determine if Os are in 
each bit position where Is are in 
(SA).lfso,setST2. 


XOR 


001010 


Exclusive OR 


Yes 


0-2 


(D) + (SA)— (D) 


MPY 


001110 


Multiply 


No 




Multiply unsigned (D) by unsigned 
(SA) and place unsigned 32-bit 
product in D (most significant) and 
D + 1 (least significant). If WR15 is 
D, the next word in memory after 
WR15 is used for the least signifi- 
cant half of the product. 


DIV 


001111 


Divide 


No 


4 


If unsigned (S A) is less than or equal 
to unsigned (D), perform no opera- 
tion and set ST4. Otherwise, divide 
unsigned (D) and (D + 1) by un- 
signed (SA). Quotient -♦ (D), re- 
mainder -♦(D + 1 ) If D = 15, the next 
word in memory after WR15 will be 
used for the remainder. 



10.5.3 Signed Multiply and Divide Instructions 



General 
Fornnat: 

The address 


12 3 


4 5 6 7 8 9 10 11 12 


13 14 15 


1 OPCODE 1 Ts 1 


s 1 


.ing mode for the source operand is determined by the Ts field. 


Ts 


S 


ADDRESSING MODE 


NOTES 


00 
01 
10 
10 

11 


0,1 15 

0,1 15 


1,2, ...,15 
1.2 15 


Workspace register 

Workspace register indirect 

Symbolic 

Indexed 

Workspace reaister indirect autoincrement 


1 

1 

1 

1,2 
1.3 



NOTES : 1 . Workspace registers and 1 contain operacKls used in the signed multiply and divide operations. 

2. Workspace register may not be used for indexing. 

3. The workspace register is incremented by 2. 
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MNEMONIC 


OPCODE 
0123466789 


MEANING 


RESULT 

COMPARED 

TOO 


STATUS 

BITS 

AFFECTED 


DESCRIPTION 


MPYS 
D!VS 


0000000111 
0000000110 


Signed Multiply 
Signed Divide 


Yes 
Yes 


0-2 
0-2,4 


Multiply signed 2's complement in- 
teger in WRO by signed 2's comple- 
ment integer in (SA) and "lace 
signed 32-bit product in WRO (most 
significant) and WR1 (least signifi- 
cant). 

If the quotient cannot be expressed 
as a signed 16-bit quantity (hex 8000 
is a valid negative number), set ST4. 
Otherwise, divide the signed, 2's 
complement integer in WRO and 
WR1 by the signed 2's complement 
integer at SA and place the signed 
quotient in WRO and the signed re- 
mainder in WR1. The sign of the 
quotient is determined by algebraic 
rules. The sign of the remainder is 
the same as the sign of the dividend , 
and|REMAINDER|< |DIVi. 






1 


2 


3 


4 


5 


6 


7 8 


9 


10 11 


12 


13 14 


15 








1 





1 


1 


D 


Ts 


S 



10.5.4 Extended Operation (XOP) Instruction 

General 
Format: 

The Ts and S fields provide multiple-mode addressing capability for the source operand. 

Depending on the value of status bit 1 1 (ST1 1 ), the XOP instruction transfers control to a user routine located either at the 
main memory address in the specified XOP trap vector, or at Macrostore. 

If ST1 1 = 0, the D field specifies the trap vector in memory that contains the addresses of the entry point and workspace of 
the user routine to be executed. The address of the trap vector is calculated as 

>0040-H >4x >D 

Following the fetch of the new WP and PC values, the effective source address (SA) is calculated and placed in WR1 1 of 
the new workspace. The old WP, PC and ST are stored inWRs 13, 14and 15, respectively. Status bit 6 is set to 1, and STs7 
through 1 1 are cleared after the old status has been saved. 

When ST1 1 = 1 , the XOP causes a trap to Macrostore if the 99000 is not in the baseline mode. The contents of the WP are 
forced to 0, and the PC is updated with the value contained at Macrostore address >0812. The new WP and PC point to 
locations within the Macrostore, where address space is logically distinct from the main memory address space. The old 
WP, PC and ST are stored in registers 13, 14 and 15, respectively, of the Macrostore workspace. Status bits 7 through 1 1 
are cleared after the old status has been saved. 

The execution of the XOP instruction is summarized below. If ST1 1 is 0, the addresses are memory addresses; if ST1 1 is 1 
and the 99000 is not in baseline mode, the addresses are in Macrostore. 



IfSTII teO: 


If ST1 1 is 1 Macrostore is entered and: 


(0040 + 4xD)- WP 


0-WP 


(0042 + 4x0) -PC 


(081 2) -PC 


SA - new WR1 1 


(0klWP)-(newWR13) 


(oklWP)-(newWR13) 


(oklPC)-(newWR14) 


(oklPC)-(newWR14) 


(oW ST) - (new WR1 5) 


(oWST)-(newWR15) 




1 - ST6 - ST9 




0-ST7 0-ST10 




0-ST8 0-*ST11 





The TMS99000 does not test interrupt requests (i.e., does not look at INTREQ ) upon completion of the XOP instruction. 
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10.5.5 Single Operand Instructions 

General 1 2 

Format: 



10 11 12 13 14 15 



OPCODE 


Is 


S 



The Ts and S fields provide multiple-mode addressing capability for the source operand. 








RESULT 


BITS 




MNEMONIC 


0123456789 


MEANING 


TOO? 


AFFECTED 


DESCRIPTION 


B 


0000010001 


Branch 


No 





SA -.-(PC) 


BL 


0000011010 


Branch and link 


No 





(PC)-^(WRII), 
SA -(PC) 


BLWP 


0000010000 


Branch and load 












workspace pointer 


No 




(SA) — (WP), (SA + 2) —(PC), (oW WP) 
— (newWR13), (old PC) — (newWR14), 


(oW ST) — (new WR15). The INTREO 












input is not tested upon completion of the 












BLWP instruction. 


CLR 


0000010011 


Clear operand 


No 





-(SA) 


SETO 


0000011100 


Set to ones 


No 





FFFF — (SA) 


INV 


0000010101 


Invert 


Yes 


0-2 


(SA) -(SA) 


NEG 


0000010100 


Negate 


Yes 


04 


-(SA)-(SA) 


ABS 


0000011101 


Absolute value* 


No 


0-4 


|(SA)| -(SA) 


SWPB 


0000011011 


Swap bytes 


No 





Bits 0-7 of (SA) — bits8-15of (SA);bits8- 
15of(SA)— bitsO-7of(SA). 


INC 


0000010110 


Increment 


Yes 


0-4 


(SA) + 1— (SA) 


INCT 


0000010111 


Increment by two 


Yes 


04 


(SA) + 2-(SA) 


DEC 


0000011000 


Decrement 


Yes 


04 


(SA)-1 -(SA) 


DECT 


0000011001 


Decrement by two 


Yes 


04 


(SA)-2-(SA) 


Xt 


0000010010 


Execute 


No 





Execute instruction located at SA. 



'Operand is compared to zero for status bit. 

tif additional memory words for the execute instruction are required to define the operands of the instruction located at S A, these words will be accessed from PC and the 

PC wilt be updated accordingly. The lAQ |ir»truction acquisition) bus status code wM not be ouput at the time the process reads the instruction at SA; instead, an SOP 

(source operand) or WS bus status code will be output. Status bits are affected in the usu^ manner for the operation performed. 

10.5.6 BIND Instruction 

General 
Format: 

The Ts and S fields provide multiple-mode addressing capability for the source operand. 

The BIND instruction serves as the inverse of a BLSK instruction if the register indirect autoincrement addressing 

mode is used. Indexed addressing used with BIND implements a powerful CASE or multi-way branch instruction 

where the immediate operand points to a table of branch addresses and the register contents selects which way to 

branch. 






1 


2 


3 


4 5 


6 


7 


8 


9 


10 11 


12 


13 14 


15 


OPCODE 


Ts 


S 



MNEMONIC 


0123466789 


MEANING 


RESULT 
TOO? 


BITS 
AFFECTED 


DESCRIPTION 


BIND 


0000000101 


Branch indirect 


No 


-- 


(SA)-(PC) 



10.5.7 Multiple-Bit I/O Instructions 

General 1 2 

Format: 



10 11 12 13 14 



15 



OPCODE 


CNT 


Ts 


S 



The I/O base address is contained in bits through 14 of WR12. If bit (the MBS) of the base address is 0, a serial I/O 
transfer will occur; othenvise (MSB = 1), a parallel I/O transfer will occur. 

In the case of a serial I / transfer, the CNT field specifies the number of bits to be transferred (from 1 to 1 6) . If CNT = 0, 1 6 
bits are transferred. The base address in WR12 defines the starting I/O bit address. The bits are transferred in bit-serial 
fashion, and the I/O base address is incremented by 2 with each bit transfer; the contents of WR1 2 are not affected. The 
effective source address in memory, specified by the Ts and S fields, is interpreted as a byte address if 8 or fewer bits are •■■ 
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transferred (CNT = 1 through 8), or as a word address if 9 or more bits are transferred (CNT = 0, 9 through 1 5). If the source 
is addressed in the woricspace indirect autoincrement mode (Ts = 3), the specified workspace register is incremented by 1 if 
CNT is in the range 1 to 8, and is incremented by 2 otherwise. If the source is addressed in the register mode (Ts = 0), bits 8 
through 15 of the specified workspace register are unchanged if the transfer is of 8 bits or less. 

In the case of a parallel I/O transfer, the CNT field determines whether a byte or word is to be transferred, and also whether 
the contents of WR12 are to be incremented by 2 following the transfer. A word transfer occurs if CNT is (binary) 1010 or 
101 1; a byte transfer occurs if CNT is 0010 or 001 1 . WR12 is post-incremented by 2 if CNT is 001 1 or 1010. All values of CNT 
besides 0010, 001 1, 1010 and 101 1 are reserved for future expansion of the parallel I/O capability and should not be used. 
The following table summarizes the use of the CNT field for a parallel I/O operation. 



TRANSFER 


CNT* 
(BINARY) 


DESCRIPTION 


byte 
transfer 


0010 


WR12 not altered 


0011 


WR12 post-incremented by 1 


word 
transfer 


1010 


WR12 not altered 


1011 


WR12 post-incremented by 2 



*Theae restrictions on the value of CNT apply only in the ciise of parallel I/O operations. 

When in user mode (ST7 = 1 ), an attempt to execute an LDCR instruction having a I/O address in the range 1 COO to 7FFE 
or 9C00 to FFFE is flagged as a privileged opcode violation . This condition generates a level 2 interrupt and inhibits writes to 
the I/O in the privileged space for the duration of the instruction. When in privileged mode (ST7 = 0), the I/O address of an 
LDCR instruction is unrestricted. When in user mode (ST7 = 1 ), an attempt to execute an STCR with an I/O address 1 COO 
to 7FFE or 9C0O to FFFE causes a privileged violation to occur after execution of the instruction. 









RESULT 


STATUS 






OPCODE 




COMPARED 


BITS 




MNEMONIC 


012346 


MEANING 


TOO 


AFFECTED 


DESCRIPTION 


LDCR 


001100 


Load communk:ation register 


Yes 


0-2,5* 


Beginning with LSB of (SA), transfer 
the specified number of bits from 
(SA) to the I/O. 


STCR 


001101 


Store communication register 


Yes 


0-2,5* 


Beginning with LSB of (SA), transfer 
the specified number of bits from the 
I/O to (SA). Load unfilled bit posi- 
tions with 0. 



*ST5 is affected only if CNT is in the range 1 to 8. 

10.5.8 Single-Bit I/O Instructions 

General 12 

Format: 



10 11 12 13 14 15 



OPCODE 


SIGNED DISPLACEMENT 



The signed displacement is added to the contents of WR12 (bits 0-14) to form the address of the I/O bit to be selected, as 
described in Section 8.2.8. 

When in user mode (ST7 = 1), iftheeffectivel/OaddressofanSBOorSBZinstructionisintherange >1C00to >7FFEor 
>9C00 to > FFFE, a privileged violation occurs (Section 4.4.3) and the I/O write is inhibited. When in privileged mode 
(ST7 = 0), no restrictions are placed on the range of the effective I/O address. 

The user is cautioned that while the SBO and SBZ instructions can be used to access the parallel I /O address space ( > 8000 
to >FFFF), and they will set or clear data bit D15 as expected, the other 15 bits (DO to D14) written to the parallel I/O 
location will be undefined. When the TB instruction is executed with an address in parallel I/O space, the bit value input on 
data line DO is read. 

When in Macrostore, the SBO, SBZ and TB instructions are not available. The SBO and SBZ opcodes perform different 
functions when in Macrostore (see Section 7.3.3.6). 
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STATUS 






OPCODE 




BITS 




MNEMONIC 


0123 4567 


MEANING 


AFFECTED 


DESCRIPTION 


SBO 


0001 1101 


Set bit to one 





Set the selected output bit to 1 . 


SBZ 


0001 1110 


Set bit to zero 





Set the selected output bit to 0. 


TB 


0001 1111 


Test bit 


2 


If the selected I/O input bit is 1 , set ST2; if 
the selected I/O input bit is 0, clear ST2. 



1 


2 


3 4 


5 


6 


7 


8 


9 10 11 12 13 14 


15 


OPCODE 


SIGNED DISPLACEMENT 



10.5.9 Jump Instructions 

General 
Format: 

Jump instructions cause the PC to be loaded with the PC-relative jump address if the selected status bits are set as 
specified; otherwise, no jump occurs and the next instruction is fetched from the word following the jump instruction . The 
jump address is computed by adding twice the signed displacement to the current value of the PC (which points to the 
word following the jump instruction). The 8-bit displacement permits the computed jump address to be specified any- 
where in the range - 128 to -i- 127 words from the address of the word that follows the jump instruction. Status register 
bits are not affected by jump instructions. 





OPCODE 




STATUS CONDITION 


MNEMONIC 


01234567 


MEANING 


TO LOAD PC 


JEQ 


00010011 


Jump equal 


ST2 = 1 


JGT 


00010101 


Jump greater than 


ST1 = 1 


JH 


00011011 


Jump high 


STO = 1 and ST2 = 


JHE 


00010100 


Jump high or equal 


STO = 1 or ST2 = 1 


JL 


00011010 


Jump low 


STO = and ST2 = 


JLE 


00010010 


Jump low or equal 


STO = or ST2 = 1 


JLT 


00010001 


Jump less than 


ST1 = and ST2 = 


JMP 


00010000 


Jump unconditional 


Unconditional 


JNC 


00010111 


Jump no carry 


ST3 = 


JNE 


00010110 


Jump not equal 


ST2 = 


JNO 


00011001 


Jump no overflow 


ST4 = 


JOG 


00011000 


Jump on carry 


ST3 = 1 


JOP 


00011100 


Jump odd parity 


STB = 1 



10.5.10 Shift Instructions 

General 

Format: 



10 11 12 13 14 15 



OPCODE 


SC 


W 



Field SC contains the shift count. W is the number of the workspace register whose contents are to be shifted. If SC = 0, 
however, bits 12 through 15 of WRO are used as the shift count. If SC = and bits 12 through 15 of WRO are 0, the 
effective shift count is 16. 









RESULT 


STATUS 






OPCODE 




COMPARED 


BITS 




MNEMONIC 


01234S67 


MEANING 


TOO 


AFFECTED 


DESCRIPTION 


SLA 


00001010 


Shift left arithmetic 


Yes 


0-4 


Shift (W) left. Fill vacated bit positions 
with 0. 


SRA 


00001000 


Shift right arithmetic 


Yes 


0-3 


Shift (W> right. Fill vacated bit positions 
with original MSB of (W). 


SRC 


00001011 


Shift right circular 






Shift (W) right. Shift previous LSB into 
MSB. 


SRL 


00001001 


Shift right logical 


Yes 


0-3 


Shift (W) right. Fill vacated bit positions 

with zeros. 

1 . — . — . 
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10.5.11 Immediate Register Instructions 
1 2 3 



General 
Format: 



10 



OPCODE 



lOP 



11 12 

iirz 



13 14 



15 



W 





OPCODE 




RESULT 


BITS 




MNEMONIC 


0123 45678 91011 


MEANING 


TOO? 


AFFECTED 


DESCRIPTION 


Al 


0000 00100 010 


Add immediate 


Yes 


0-4 


(W) + IOP-*(W) 


ANDI 


0000 00100 100 


AND immediate 


Yes 


0-2 


(W)ANDIOP— iW) 


CI 


0000 00101 000 


Compare immediate 


Yes 


0-2 


Compare (W) to lOP and set ap- 
propriate status bits. 


LI 


0000 00100 000 


Load immediate 


Yes 


0-2 


lOP — (W) 


OR! 


0000 00100 110 


OR immediate 


Yes 


0-2 


(W) OR lOP — 


BLSK 


0000 00001 01 1 


Branch immediate and push link 












to stack 


No 





(W)-2-(W), (PC) + 4-((W) 
lOP — (PC) 



10.5.12 Internal Register Load Immediate Instructions 

01 23456789 10 11 12 13 14 15 



General 
Format: 



OPCODE 



lOP 



3 



When in user mode (ST7 = 1 ), execution of the LIMI instruction is flagged as a privileged opcode violation (Section 4.4.3). 



MNEMONIC 


OPCODE 
0123 4567 8910 


MEANING 


DESCRIPTION 


LWPI 
LIMI 


0000 0010 111 
0000 0011 000 


Load workspace pointer immediate 
Load interrupt mask immediate 


lOP — (W) not status bits affected. 

lOP - ST bits 1 2 thru 1 5, ST1 2 thru ST1 5. 



10.5.13 Internal Register Load and Store Instructions 

12 3 4 5 



General 
Format: 



6 



10 11 12 13 14 15 



OPCODE 



W 









STATUS 






OPCODE 




BITS 




MNEMONIC 


0123 4567 891011 


MEANING 


AFFECTED 


DESCRIPTION 


STST 


0000 0010 1100 


Store status Register 





(ST) - (W) 


LST 


0000 0000 1000 


Load status Register 


0-15 


(W) -* (ST) 


STWP 


0000 0010 1010 


Store workspace pointer 





(WP) - (W) 


LWP 


0000 0000 1001 


Load workspace pointer 





(W) ^ (WP) 



While in privileged mode (ST7 = 0), the LST instruction modifies all 16 bits of the status register. While in user mode (ST7 
= 1 ), only bits through 5 and bit 1 of the workspace register specified in the W field are placed in the status register; ST6 
is cleared and the other status register bits are unaffected. 
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1 


2 


3 


4 


5 


6 


7 


8 


9 


10 


11 


12 


13 


14 


15 




















1 


1 


1 
























10.5. 14 Return Workspace Pointer ( RTWP) I nstruction 

General 
Format: 

The RTWP instruction causes the following transfers to occur: 

(WR15) -^ (ST) 
(WR14)-(PC) 
(WR13)-(WP) 

When in privileged mode ( ST7 = 0), the RTWP instruction causes the entire contents of WR 1 5 to be loaded into the status 
register. In user mode (ST7 = 1 ), only bits through 5 and 10 of WR15 are loaded into the status register; ST6 is cleared 
and the other status register bits remain unaffected. 

When in Macrostore, several variations of the RTWP instruction opcode are available. These are opcodes >0381 , > 0382, 
and >0384. These opcodes are summarized below. More detail in the operation of these special opcodes is given in 
Section 7.3.2 



RTWP Opcode 



>0380 
>0381 
>0382 
>0384 

10.5.15 External Instructions 



Function 



RTWP when in main memory or exit from Macrostore with interrupts sampled 
RTWP when in Macrostore memory (does not cause exit from Macrostore) 
Exit from Macrostore with level 2 trap 
Exit from Macrostore and suppress interrupt sampte. 






1 


2 


3 


4 5 


6 


7 


8 


9 


10 


11 


12 


13 


14 


15 


OPCODE 




















General 
Rmnat: 

Extemal instructions cause a bit value of to be written to a I /O address 1 ECX, where the hexadecimal digit represented as 
"X" depends upon the particular external instruction being executed. During execution of the RSET, CKOF, CKON and 
LREX instructions, the WE/IOCLK output is pulsed low once. With the completion of the single I/O write cycle, execution 
of the external instruction is finished, and the processor proceeds to the next instruction. While in privileged mode (ST7 = 
0), execution of RSET causes the inten-upt mask (ST12-ST15) to be cleared. None of the other external instructions affect 
the status register. 

When the IDLE instruction is executed, the processor enters the idle state, where it remains unti l a Reset, NMI, APP, or 
unmasked extemal intenrupt occurs. While in the idle state, the processor pulses the WE/IOCLK output repeatedly, with 
each I/O write cycle accompanied by a I / bus status code (Table 2) . The PC value saved during the context switch to the 
Reset, NMI or interrupt service routine points to the instruction following the IDLE. 

When in user mode (ST7 = 1 ), execution of an external instruction is flagged as a privileged opcode violation (Section 
4.4.3). 









STATUS 




I/O 




OPCODE 




BITS 




ADDRESS 


MNEMONIC 


0123 4S67 8910 


MEANING 


AFFECTED 


DESCRIPTION 


IN HEX 


IDLE 


0000 0011 010 


Idle 




Suspend processor instruction 
execution until an intermpt, 
NMI or Reset occurs. 


1EC4 


RSET 


0000 001 1 01 1 


Reset 


12-15 


Clear inten-upt mask (ST1 2- 
ST15) 


1EC6 


CKOF 


0000 0011 110 


User-defined 







1ECC 


CKON 


0000 0011 101 


User-defined 








1ECA 


LREX 


0000 0011 111 


User-defined 








1ECE 
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10.5.16 Bit-Manipulation instructions 

General 






1 


2 


3 


4 


5 


6 


7 8 


9 


10 11 


12 


13 14 


15 


OPCODE j 






















BIT DISP 


1 


Ts 


1 


S 





Format: 



The Ts and S fields provide multiple-mode addressing capability for the source operand. The indirect autoincrement 
addressing mode (Ts = 3), however, is undefined for the TMB, TCMB and TSMB instructions. If the two bits of the Ts 
field are 3, an MID trap occurs. 

Bit-manipulation instructions copy the specified memory bit into status bit 2, and set or clear the specified memory bit. In 
order to provide an indivisible test-and-set operation, the MPILCK (multiprocessor interlock} bus status code is active 
during the critical portions of the TSMB and TCMB instructions, except in the case Ts = (register addressing mode). 









STATUS 






OPCODE 




BITS 




MNEMONIC 


IN HEX 


MEANING 


AFFECTED 


DESCRIPTION* 


TMB 


0C09 


Test memory bit 


2 


(SA + BD)-ST2 


TCMB 


OCOA 


Test and clear memory bit 


2 


(SA + BD) - ST2, - (SA + BD) 


TSMB 


OCOB 


Test and set memory bit 


2 


(SA + BD) - ST2, 1 - (SA + BD) 



*BD is used above to refer to the contents of the bit-displacement field. 

If the leading 6 bits in the predefined field of the second word of the instruction are not as specified, an MID trap occurs. 
10.5.17 Double-Precision Arithmetic Instructions 
General Format: 



1 



8 



10 11 12 13 14 15 



ADD/SUB 



SHIFT 



OPCODE 1 





1 








Td 


D 


Ts 1 


s 1 




OPCODE 1 





1 











1 sc 1 


Ts 


s 









STATUS 






OPCODE 




BITS 




MNEMONIC 


(HEX 


MEANING 


AFFECTED 


DESCRIPTION 


AM 


002A 


Add double 


0-4 


(SA,SA-i-2) + (DA,DA + 2) - (DA, DA +2) 


SM 


0029 


Subtract double 


0-4 


(DA,DA + 2) - (SA,SA + 2)-(DA,DA + 2) 


SLAM 


001 D 


Shift left arithmetic double 


0-4 


Shift (SA,SA + 2) left. Fill vacated bit posi- 
tions with 0. If SC=0, count is in bits 4 
through 7 of WRO. 


SRAM 


001 C 


Shift right arithmetic double 


0-3 


Shift (SA,SA-i-2) right. Fill vacated bit posi- 
tions with MSB. If SC=0, count is in bits 4 
through 7 of WRO. 



If the two bits in the Ts or Td field are 3 (workspace register indirect autoincrement addressing mode) the contents of the 
corresponding workspace register are incremented by 4. 

If SC = in the shift instructions, the shift count is taken from bits 4 through 7 of WRO, which are interpreted as an 
unsigned 4-bit integer. If bits 4 through 7 of WRO are 0, then the effective shift count is 0. Bits shifted out are shifted into 
STB. If the shift count is 0, ST3 is set to 0. 

During a SRAM the sign bit fills the vacated positions. During a SLAM, zeros fill the vacated* positions. 

If the bits in the predefined field of the second word of the instruction are not as specified, an MID trap occurs. 
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10.5.18 MID Opcodes 

The single-word instruction opcodes that cause an MID trap (see Section 4.4.2) are: 

0000-001 B 02D(H)2DF 

001E-0028 02E1-02FF 

002B-007F 0301-033F 

OOAO-OOAF 0341-035F 

00C0-013F 0361-ra7F 

0210-021 F 0381-039F 

0230-023F 03A1-03BF 

0^0-O^F 03C1-03DF 

0270-027F 03E1-03FF 

0780-07FF 

0290-029F 0C00-0C08 

02B0-02BF OCOC-OFFF 

10.6 INSTRUCTION EXECUTION 

10.6.1 Microinstruction Cycle 

The TMS99000 microprocessor is a microcoded machine. Each instruction in the 99000 instruction set is executed 
internally as a sequence of microinstructions, the length of the sequence varying according to the particular instruction. 
Each microinstruction cycle is minimally one machine state in duration but can be extended with wait states by activating 
the READY input. The term "wait-state" is used to describe the condition where the processor is "frozen" in its 
present state and consequently cannot advance to the next state. In the 99000, all types of bus cycle -memory, 
I/O or internal -can be extended with wait-states. The ALATCH output toggles exactly once at the beginning of 
each microinstruction cycle. 

10.6.2 Opcode Prefetching 

The TMS99000 increases its effective processing speed by prefetching opcodes where pc^sibie. By allowing successive 
bus cycles to be overlapped, as shown in Figure 27, the time required to fetch the opcode from memory and decode it 
becomes transparent when no wait states are required. In preceding a typical instruction, e.g., register-to-register add, 
the TMS99000 performs the following sequence of steps: 

1 . Fetch instruction 

2. Decode instruction 

3. Fetch source operand, if needed 

4. Fetch destination operand, if needed 

5. Process the operands 

6. Store the results, if required 

The prefetch mechanism of the 99000 makes use of the fact that the processor's memory interface can operate in parallel 
with operations involving the processor's internal buses and registers. For example, during step 5 above, the memory bus 
is not needed by the current instruction, which is busy processing the operands internally. Hence, this time can be used to 
prefetch the opcode for the next instruction. This overlapping is seen in Figure 32, where "Ml" indicates an operation 
performed by the memory interface, and "OP" denotes an internal operation. Deterministic: a prefetched opcode is 
discarded only in the event that an interrupt occurs. Steps 1 and 2 above should really be considered part of the preceding 
instruction. In other words, each instruction is responsible for prefetching the opcode for the next instruction. This 
reduces the effective overhead of the typical instruction sequence given above to the four steps, 3-6. Without 
overlap, the overhead would be six rather than four steps. 

The instruction prefetch scheme employed by the 99000 can cause self-modifying software to execute incorrectly. 
Incorrect execution results when one instruction attempts to generate the opcode of the very next instruction to be 
executed. The TMS99000 fetches the opcode of the next instruction before storing the result of the current instruction. 
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Ml = memory interface 



0P= intemal operation 
FIGURE 32 - OVERLAPPED INSTRUCTION EXECUTION 



10.6.3 TMS99000 Instruction Execution Times 

Instruction execution times for the TMS99000 are a function of the: 

• Machine state time ts (four times the external input clock period), 

• Particular addressing mode used in the event that the instruction provides multiple-mode addressing capability, and 

• Number of wait states required per memory access. 

Table 16* lists the numlier of machine states and memory accesses required to execute each 99000 instruction. For 
instructions providing multiple addressing modes for one or both operands, the table lists the number of states and 
memory accesses with ail operands addressed in the worlcspace register mode. To determine the additional number of 
states and memory accesses required for the other addressing modes, add the appropriate values from the table. The total 
execution time for an instruction, assuming all memory requires the same number of wait states, is calculated as: 

T = tslC + WM) 
where: 

T = total instruction execution time 

ts = machine state time (four times the external input clock period) 
C = number of states for instruction execution plus address modification 

W = number of required wait states per memory access for instruction execution plus address modification 
M = number of memory accesses 

For example, consider a MOV instruction executed in a system for which ts = 0. 1 67 jLisec. Assume that no wait states are 
required to access memory, and that Isoth operands are accessed in workspace register mode: 

T = ts(C+ WM) = 0.167(3 + 0x3) ^isec = 0.50 /isec 
If two wait states per memory access are required, the execution time becomes 

T = 0.167(3 + 2x3) fisec = 1.50 fisec 
If the source operand was addressed in the symisolic mode and two wait states are required, then 

T = tc(C + WM), 

C = 3 + 1 = 4, 

M = 3 + 1 = 4, 

T = 0.167(4 + 2x4) fisec = 2.0 /Ltsec 

* Instruction prefetching is accounted for in Table 16. The table gives exact cycle counts required for Instruction execution. 
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TABLE 16- INSTRUCTION EXECUTION TIMES 



- 


MACHINE 


MEMORY 


ADDRESS 


INSTRUCTIONS 


STATES 
C 


ACCESS 
M 


MODIFICATION 


SOURCE 


DEST 


A 


4 


4 


A* 


A 


AB 


4 


4 


A 


A 


ABS 


5 


3 


A 


— 


Al 


4 


4 


- 


— 


AM 


12 


8 


A 


A 


ANDI 


4 


4 


- 


— 


B 


3 


1 


A 


— 


BIND 


4 


2 


A 


— 


BL 


5 


2 


A 


— 


BLSK 


7 


5 


- 


— 


BLWP 


10 


6 


A 


— 


C 


4 


3 


A 


A 


CB 


4 


3 


A 


A 


CI 


4 


3 


- 


— 


CKON 


9 


1 


— 


— 


CKOF 


9 


1 


- 


— 


CLR 


3 


2 


A 


- 


COC 


4 


3 


A 


- 


CZC 


4 


3 


A 


- 


DEC 


3 


3 


A 


- 


DECT 


3 


3 


A 


- 


DIV(ST4isset) 


6or10 


4 


A 


— 


DIV(ST4isreset)t 


30 


6 


A 


— 


DIVS<ST4isset) 


10,13 or 33 


4 


A 


— 


DIVS(ST4 is reset) t 


34 


6 


A 


— 


IDLE 


9+2xN 


1 


- 


— 


INC 


3 


3 


A 


- 


INCT 


3 


3 


A 


- 


INV 


3 


3 


A 


— 


JUMP (PC is changed) 


3 


1 


— 


— 


(PCIs not changed) 


3 


1 


— 


— 


LDCR{CNT = 0, serial) 


40 


3 


A 


— 


(CNT=)fcO, serial) 


8+2XCNT 


3 


A 


— 


(MSB R12= 1, autoincrement R12) 


8 


4 


A 


— 


(MSB R12 = 1, R12notautoincremented) 


8 


3 


A 


- 


LDDandLDS* 










LI 


3 


3 


- 


— 


LIMI 


5 


2 


- 


- 


LMFt 










LREX 


9 


1 


— 


— 


LST 


7 


2 


— 


— 



* Replace the letter "A: with appropriate value from Table A. The C and M values from Table A for the addressing mode used must be added to the C and M 
values from this table. 

^ Execution time is dependent upon the partial quotient after each clock cycle during execution. 

* Execution time is added to the execution time of the source address. 
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TABLE 16 - INSTRUCTION EXECUTION TIMES (CONCLUDED) 





MACHINE 


MEMORY 


ADDRESS 


INSTRUCTIONS 


STATES 


ACCESS 


MODIFICATION 




C 


M 


SOURCE 


DEST 


LWP 


3 


2 







LWPI 


3 


2 







MOV 


3 


3 


A* 


A 


MOVB 


4 


4 


A 


A 


MPY 


23 


5 


A 




MPYS 


25 


5 


A 




NEG 


3 


3 


A 




ORI 


4 


4 






RSET 


9 


1 


_ 




RTWP1 


9/7 


4 





_ 


S 


4 


4 


A 


A 


SB 


4 


4 


A 


A 


SBC 


7 


2 


_ 




SBZ 


7 


2 






SETO 


3 


2 


_ 




SHIFT {SC:^0) 


5-f^SC 


3 


_ 




(SC = and bits 12-15 of WR = 0) 


23 


4 


_ 




{SC = and bits 12-1 5 of WR^tO) 


7 + SC 


4 







SM 


12 


7 


A 


A 


SOC 


4 


4 


A 


A 


SOCB 


4 


4 


A 


A 


SHIFT MULTIPLE (SC = 0) 


11-t-SC 


5 


A 




(SC^O) 


13 + SC 


6 


A 




STCR(CNT = 0, serial) 


43 


3 


A 




{CNT = 1to7) 


20 + CNT 


4 


A 




(CNT=8) 


27 


4 


A 




(CNT = 9to15) 


20-hCNT 


3 


A 


_ 


(MSB R12 = 1, autoincrement R12) 


10 


5 


A 




(MSB R12 = 1, R12 notautoincremented) 


10 


4 


A 




STST 


3 


2 






STWP 


3 


2 


_ 




SWPB 


3 


3 


A 




SZC 


4 


4 


A 


A 


SZCB 


4 


4 


A 


A 


TB 


7 


2 







TEST MEM BIT 


26 


3 


A 




X§ 


2 


1 


A 




XOP(ST11=0) 


14 


7 


A 




XOR 


4 


4 


A 




Reset function 


13 


6 






Interrupt context switch 


13 


6 


_ 




MID opcode (Macrostore) 


14S 










(attached processor) 


21 § 


8 


— 


— 



• Replace the letter "A" with appropriate value from Table A. The C and M values from Table A for the addressing mode used must be added to the C and M 
values from this table. 

§Execution time does not include the time required by software or an attached processor to emulate the instruction. 

1RTWP, when staying in Macrostore, takes seven machine states. When not in Macrostore or exiting MacrostoiB, RTWP takes nine machiiw states. 

TABLE A 



ADDRESSING MODE 



WR(TsorTd = 0) 

WR indirect (Ts or Td = 1 ) 

WR indirect autoincrement (Ts or Td = 3) 

Symbolic (Ts or Td = 2, S or D = 0) 

Indexed (Ts or Td = 2, S or D = 0) 



MACHINE 

STATES 

C 



MEMORY 

ACCESS 

M 
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10.6.4 Bus Status Code Sequences 






This section presents the sequence of bus status codes output oy tne microprocessor aunng eaui. \ ./ m^uu^uy^n z^^^^v.- 
tion, <2) interrupt trap, (3) MID trap and (4) transfer of control between the TMS99000 and an attached processor. 

The TMS99000 microprocessors are microcoded machines. Each instruction in the instruction set is executed internally as 
a sequence of microinstructions, the length of the sequence varying according to the particular instruction. Each microin- 
struction cycle is minimally one machine state in duration but can be extended with wait states by activating the READY 
input. The sequence of machine states generated during the execution of a particular instruction depends upon the 
opcode and the addressing modes used. 

A typical instruction contains an opcode and addressing modes for up to two operands (source and destination). The 
execution of an instruction can similarly be divided into two parts: (1) the derivation of the operands from the specified 
addressing modes, and 12) the execution of the operation specified by the opcode. Since the same addressing modes are 
common to many instructions, the portion of the execution sequence corresponding to each addressing mode can be 
listed separately from the basic execution sequences for the various instructions. The listing of these sequences in separate 
tables is done in this section for the sake of brevity. 

Using this infonnation, the user can reconstruct the entire sequence for a particular instruction by inserting the sequences 
corresponding to the addressing modes into the basic sequence given for the instruction. The basic execution sequences 
for the various TMS99000 instructions are presented in Table 14. In this table, the sequences corresponding to the source 
and destination addressing modes are represented by the symbols <SRC > and <DST>, respectively. These symbols 
must be replaced by the appropriate sequences from Tables 1 5 and 16 to reconstruct the entire execution sequence for the 
instruction with its particular addressing modes. 

An example will help to illustrate this procedure. Consider the following add instruction: 

A*R1 + ,R2 
The addressing mode used to locate the source operand is register indirect autoincrement with R1 . The addressing mode 
used to locate the destination operand is register direct with R2. Table 14 presents a complete list of the machine states 
generated during the execution of this instruction. Each state is identified by the bus status code output during that state. 
Refer to Table 2 of Section 3 for a list of all bus status codes and their mnemonics. The fetching of the A (add) opcode is not 
shown in Table 1 4; instead, the next to the last state shown is the prefetch of the opcode for the instruction that follows the 
add. This convention will be follovsred throughout Table 17. The prefetch of the opcode for the next instruction is 
considered to be part of the execution sequence of the current instruction. 

Using the data presented in Tables 18, 19 and 20, the information presented in the example of Table 17 is constructed as 
follows. The basic execution sequence for the A (add) instruction is presented at the beginning of Table 18. Here the 
execution sequences for the source and destination addressing modes are represented by the symbols <SRC > and 
<DST>. These symbols are replaced by the appropriate addressing mode sequences from Table 18 to generate the 
sequence seen in Table 17. The symbols Ns and Nd in Table 17 represent the number of machine cycles required to derive 
the source and destination operands, respectively, and are replaced by the appropriate numbers from Table 18. 

The execution sequences for all other TMS99000 instructions and operations shown in Table 17 are generated in similar 
fashion. 

TABLE 17- EXAMPLE INSTRUCTION SEQUENCE FOR AN A "Rl + ,R2 



NUMBER 


BUS 




READ 




OF 


STATUS 




OR 




CYCLES 


CODE 


NAME 


WRITE 


COMMENT 




0110 


ws 


R 


Fetch source operand from WR1 


Ns = 4 


1001 


AUMS 


- 


Internal operation 




0110 


WS 


W 


Increment WR1 




0001 


SOP 


R 


Read source operand 


Ncl=1 


0110 


WS 


R 


Read dest'n operand from WR2 


1 


0011 


lAQ 


R 


Prefetch next instruction 


1 


0110 


WS 


W 


Write sum to WR2 
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TABLE 18-SOURCE ADDRESSING MODE SEQUENCES 



NUMBER 


BUS 




READ 






OF 


STATUS 




OR 






CYCLES 


CODE 


NAME 


WRITE 


COMMENT 




Workspace Register Source Addressing, R 




1 0110 


WS 


- 


Get source operand from WR 


Ns= 1 


Woricspace Register Indirect Source Addressing, "R 




1 


0110 


ws 


R 


Get source address from WR 




1 


0001 


SOP 


R 


Fetch source operand 


Ns = 2 


Workspace Register Indirect Autoincrement Source Address, 


•R + 






1 


0110 


ws 


R 


Get source address from WR 




1 


1001 


AUMS 








1 


0110 


ws 


W 


Increment WR contents 


Ns = 4 


1 


0001 


SOP 


R 


Fetch source operand 




Symbolic (Direct) Source Address, ©LABEL 




1 


0010 


lOP 


R 


Get source operand address 




1 


0001 


SOP 


R 


Fetch source operand 


Ns = 2 


Indexed Source Address, @TABLE(R) 


1 


0110 


ws 


R 


Fetch base address from WR 




1 


0010 


lOP 


R 


Fetch index 




1 


1001 


AUMS 






Ns = 4 


1 


0001 


SOP 


R 


Fetch source operand 




Workspace Register Destination Address, R 








1 


0110 


ws 


R 


Get dest'n operand from WR 


Nd = 1 


Workspace Register Indirect Destination Address, *R 


1 


0110 


ws 


R 


Get dest'n address from WR 




1 


0100 


DOP 




Fetch dest'n operand 


Nd = 2 


Workspace Register Indirect Autoincrement Destination Addr 


9SS, *R + 






1 


0110 


ws 


R 


Get dest'n address from WR 




1 


1001 


AUMS 








1 


0110 


ws 


W 


Increment contents of WR 


Nd = 4 


1 


0100 


DOP 


R 


Fetch dest'n operand 




Symbolic (Direct) Destination Address, S)LABEL 


1 


0010 


lOP 


R 


Fetch dest'n address 




1 


0100 


DOP 


R 


Fetch dest'n operand 


Nd = 2 


Indexed Destination Address, @TABLE(R) 


1 


0110 


ws 


R 


Fetch base address from WR 




1 


0010 


lOP 


R 


Fetch index 




1 


1001 


AUMS 






Nd = 4 


1 


0100 


DOP 


R 


Fetch dest'n operand 
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TABLE 19 - INSTRUCTK)N EXECUTION SEQUENCES 



NUMBER 

OF 
CYCLES 


BUS 

STATUS 

CODE 


NAME 


READ 

OR 
WRITE 


COMMENT 


A, AB, MOVE, S, SB, SOC, SOCB, SZC, SZCB (See MOV sequence below) 


Ns 
Nd 

1 
1 


0011 
0100* 


<SRC> 

<DST> 

lAQ 

DOR* 


R 
R 


Fetch source operand 
Fetch dest'n operand 
Prefetch next instruction 
Save result at dest'n address 


MOV (move word) 


Ns 
Nd-1 

1 
1 


0011 
0100* 


<SRC> 

<DST> 

lAQ 

DOR* 


R 
R 


Fetch source operand 
Get dest'n address, but block fetch t 
Prefetch next instruction t 
Write operand to dest'n address 


SLA, SRA, SRC, SRL (if shift count is NOT zero) 


1 
2 
CNT* 
1 
1 


0110 
1001 
1001 
0011 
0110 


WS 

AUMS 

AUMS 

lAQ 

WS 


R 

R 
W 


Fetch source operand from WR 
Series of 2 consecutive AUMS cycles 
Repeat shift operation 
Fetch next instruction 
Save result in source WR 


SLA, SRA, SRC, SRL (if shift count is zero) 


1 
1 
1 
2 
CNT* 

1 

1 


0110 
1001 
0110 
1001 
1001 

0011 
0110 


WS 
AUMS 

WS 
AUMS 
AUMS 

lAQ 
WS 


R 
R 

R 
W 


Fetch source operand from WR 

Fetch shift count from WRO 

Series of 2 consecutive AUMS cycles 

Repeat shift operation 

Prefetch next instruction 
Save result in source WR 


ABS (source operand in workspace register) 


1 

1 
1 
1 
1 


0110 
1001 
0110 
0011 
1001 


WS 

AUMS 

WS 

lAQ 

AUMS 


R 

R 
R 


Fetch source operand from WR 

Save result in source addrras 
Prefetch next instruction 


ABS (non-worl<space source operand) 


Ns-1 
1 
1 
1 

1 
1 


0000 
1000 
0001 
0011 
1001 


<SRC> 

SOPL 

AUMSL 

SOR 

lAQ 
AUMS 


R 

R 
R 


Devebp address of source operand 
Fetch source operand (MRILCK active) 

Save result in source address 
Prefetch next instruction 


Al, ANDI, ORI 


1 
1 
1 
1 


0110 
0010 
0011 
0110 


WS 
lOR 
lAQ 
WS 


R 
R 
R 
W 


Fetch source operand from WR 
Fetch immediate operand 
Prefetch next instruction 
Save result in source WR 



'Substitute WS bus status code if oparand is In workspace register. 

tThe last state of the destination operand derivation sequence Is replaced by an Instruction fetch. 

^Number of cycles is equal to shift count. 



TABLE 19 - INSTRUCTION EXECUTION SEQUENCES (CONTINUED) 



NUMBER 


BUS 




READ 




OF 


STATUS 




OR 




CYCLES 


CODE 


NAME 


WRITE 


COMMENT 


C,CB 


Ns 




<SRC> 




Fetch source operand 


Nd 




<DST> 




Fetch dest'n operand 


1 


0011 


lAQ 


R 


Prefetch next instruction 


1 


1001 


AUMS 






CI 


1 


0110 


WS 


R 


Fetch source operand from WR 


1 


0010 


lOP 


R 


Fetch imnriediate operand 


1 


0011 


lAQ 


R 


Fetch next instruction 


1 


1001 


AUMS 






AM, SM (double-word add and subtract) 


1 


0010 


lOP 


R 


Fetch second word of instruction 


1 


1001 


AUMS 






Ns 




<SRC> 




Fetch MSW of source operand 


Nd-1 




<DST> 




Develop destination addresst 


1 


1001 


AUMS 




Operand fetch is blocked 


1 


1001 


AUMS 






1 


0001 • 


SOP* 


R 


Fetch LSW of source operand 


1 


0100* 


DOP* 


R 


Fetch MSW of dest'n operand 


1 


1001 


AUMS 






1 


0100* 


DOP* 


W 


Write LSW of result to dest'n address 


1 


0100* 


DOP* 


R 


Fetch MSW of dest'n operand 


1 


0011 


lAO 


R 


Prefetch next instruction 


1 


0100* 


DOP* 


W 


Write MSW of result to dest'n address 


B 

Ns-1 




<SRC> 




Get source addresst 


1 


1001 


AUMS 




No fetch of source operand 


1 


0011 


lAO 


R 


Prefetch next instruction from effective source address 


1 


1001 


AUMS 






BIND 


Ns 




<SRC> 




Fetch source operand 


1 


1001 


AUMS 






1 


0011 


lAO 


R 


Prefetch next instruction from effective source address 


1 


1001 


AUMS 






BL 


Ns 




<SRC> 




Fetch source operand 


2 


1001 


AUMS 




Series of 2 consecutive AUMS cycles 


1 


0011 


lAQ 


R 


Prefetch next instruction 


1 


0110 


WS 


W 


SaveokJPCinWRH 



'Replace with WS bus status code if operand is in workspace registers. 
tBk>ck the read cycle In the last cyde of the source fetch sequence. 
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TABLE 19 - INSTRUCTION EXECUTION SEQUENCES (CONTINUED) 



NUMBER 


BUS 




READ 




OF 


STATUS 




OR 




CYCLES 


CODE 


NAME 


WRITE 


COMMENT 


BLSK 


1 


0110 


ws 




Fetch stack pointer from WR 


1 


1001 


AUMS 






1 


0110 


WS 


W 


Decrement stack pointer in WR 


1 


0010 


lOP 


R 


Fetch branch address 


1 


0001 


SOP 


W 


Push return PC onto stack 


1 


0011 


lAG 


R 


Fetch next instruction 


1 


1001 


AUMS 






BLWP 


Ns 




<SRC> 




Fetch source operand (the new WP) 


2 


1001 


AUMS 




Series of 2 consecutive AUMS cycles 




ooor 


SOP' 


R 


Fetch new PC 




1100 


WP 




New WP is output on address lines 




0110 


WS 


W 


SaveoldWPinWR13 




0110 


WS 


W 


SaveoWPCinWRM 




0110 


WS 


W 


SaveoklSTinWRlB 




0011 


lAQ 


R 


Prefetch next instruction 




1001 


AUMS 






CLR, SETO 


Ns-1 




SRO 




Get source addresst 


1 


1001 


AUMS 




No fetch of source operand 


1 


0011 


lAQ 


R 


Prefetch next instruction 


1 


ooor 


SOP* 


W 


Save result in source address 


coc, czc 


Ns 




<SRC> 




Fetch source operand 


1 


0110 


WS 


R 


Fetch dest'n from deagnated WR 


1 


0011 


lAQ 


R 


Prefetch next instruction 


1 


1001 


AUMS 






DIV 


Ns 




<SRC> 




Fetch source operand 


1 


1001 


AUMS 






1 


0110 


WS 


R 


Fetch MSW of dest'n operand from WR 


IF OVERFLOW, GO TO LABEL 1 






Check for divide by zero 


1 


0110 


WS 


R 


Fetch LSW of dest'n operand from WR + 1 


4 


1001 


AUMS 




Series of 4 consecutive AUMS cycles 


IF OVERFLOW, GO TO LABEL 1 






Is divisor < M S W of dividend? 


18 


1001 


AUMS 




Series of 18 consecutive AUMS cycles 


1 


0110 


WS 


W 


Save quotient in dest'n WR 


1 


0011 


lAQ 


R 


Prefetch next instruction 


1 


0110 


WS 


W 


Save remainder in dest'n WR + 1 


LABEL 1 : (60 HERE IF OVERFLOW) 








1 


0011 


lAQ 


R 


Prefetch next instruction 


1 


1001 


AUMS 







'Substitute WS bus status code if operand is in workspace register. 
tBk>ck the read in the last cycle of the source fetch sequence. 
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TABLE 19 - INSTRUCTION EXECUTION SEQUENCES (CONTINUED) 



NUMBER 


BUS 




READ 




OF 


STATUS 




OR 




CYCLES 


CODE 


NAME 


WRITE 


COMMENT 


Div'S 






Ns 

1 


1001 


<SRC> 
AUMS 




Fetch source operand 


1 


0110 


ws 


R 


Fetch LSW of dest'n operand from WR1 


1 


1001 


AUMS 






1 


0110 


WS 


R 


Fetch MSW of dest'n operand from WRO 


3 


1001 


AUMS 




Series of 3 consecutive AUMS cycles 


IF OVERFLOW, GO TO LABEL 1 






Check for divide by zero 


3 1001 


AUMS 




Series of 3 consecutive AUMS cycles 


IF OVERFLOW, GO TO LABEL 1 






Is 1 divisor! < |dividend|? 


20 1001 


AUMS 




Series of 20 consecutive AUMS cycles 


IF OVERFLOW, GO" 


ro LABEL 1 






Does unsigned quotient overflow its 15-blt boundary? If so, 
set ST4. 


1 


0110 


WS 


W 


Save quotient in WRO 


1 


0011 


lAQ 


R 


Prefetch next instruction 


1 


0110 


WS 


W 


Save remainder in WR1 


LABEL 1: (GO HERE IF OVERFLOW) 








1 


0011 


lAQ 


R 


Prefetch next instruction 


1 


1001 


AUMS 






DEC, DECT, INC, INCT, INV, NEG, SWA 


PB 


Ns 




<SRC> 




Fetch source operand 


1 


0011 


lAQ 


R 


Prefetch next instruction 


1 


0001* 


SOP* 


R 


Save result in source address 


LREX, CKOF, CKON, RSET (external inst 


ructions) 


4 


1001 


AUMS 




Series of 4 consecutive AUMS cycles 


2 


1011 


I/O 


W 


I/O cycle is minimum 2 states long 


1 


1101 


ST 




Output new status on address bus 


1 


0011 


lAQ 


R 


Prefetch next instruction 


1 


1001 


AUMS 






IDLE (external Instruction) 


3 


1001 


AUMS 




Series of 3 consecutive AUMS cycles 


2 


1011 


I/O 


W 


I/O cycle is minimum 2 clocks long 


1 


0011 


lAQ 


R 


Fetch next instruction 


1 


1001 


AUMS 






LDCR (parallel load CRU) 


Ns 




<SRC> 




Fetch source operand 


1 


0110 


WS 


R 


Get CRU base address from WR12 


2 


1001 


AUMS 




Series of 2 consecutive AUMS cycles 


2 


1001 


I/O 


W 


I/O cycle is minimum 2 states king 


1 


0011 


lAO 


R 


Fetch next instruction 


1 


loon 


AUMSt 




Increment WR12 if necessary 



'Substitute WS bus status code If operand is in workspace register. 

* Substitute WS bus status code and a write cycle if WR12 is post-incremented by 2. 
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TABLE 19 - INSTRUCTION EXECUTION SEQUENCES (CONTINUED) 



NUMBER 


BUS 




READ 




OF 


STATUS 




OR 




CYCLES 


CODE 


NAME 


WRITE 


COMMENT 


LDCR (serial load CRl 


J) 


Ns 




<SRC> 




Fetch source operand 


1 


0110 


ws 


R 


Fetch CRU base address from WR12 


4 


1001 


AUMS 




Series of 4 consecutive AUMS cycles 


2* CNTt 


1011 


I/O 


W 


I/O cycle is minimum 2 states long 


1 


0011 


lAO 


R 


Fetch next instruction 


1 


1001 


AUMS 






LDD AND LDS 










1 


1001 


AUMS 






1 
1 


1001 
1001 


AUMS 
AUMS 




Update internal LDD and LDS flags 
MID trap follows 


LI 

1 


0010 


lOP 


R 


Fetch immediate operand 


1 


0011 


lAQ 


R 


Fetch next instruction 


1 


0110 


WS 


W 


Save operand in specified WR 


LIMI 




1 


0010 


lOP 


R 


Fetch immediate operand 


2 


1001 


AUMS 




Series of 2 consecutive AUMS cycles 


1 


0011 


lAQ 


R 


Prefetch next instruction* 


1 


1001 


AUMS 






LSI 




1 


0110 


WS 


R 


Fetch operand from WR 


3 


1001 


AUMS 




Series of 3 consecutive AUMS cyctes 


1 


1101 


ST 




Output new status on address bus 


1 


0011 


lAQ 


R 


Fetch next instruction 


1 


1001 


AUMS 






LWP 




1 


0110 


WS 


R 


Fetch operand from WR 


1 


0011 


lAQ 


R 


Fetch next instruction 


1 


1100 


WP 




Output new WP on address bus 


LWPI 






1 


0010 


lOP 


R 


Fetch immediate operand 


1 


0011 


lAQ 


R 


Fetch next instruction 


1 


1100 


WP 




Output new WP on address bus 


MPY 


Ns 




<SRC> 




Fetch source operand 


1 


0110 


WS 


R 


Fetch dest'n operand from WR 


18 


1001 


AUMS 




Series of 18 consecutive AUMS cycles 


1 


0110 


WS 


W 


Save MSW of result in WR 


1 


0011 


lAQ 


R 


Fetch next instruction 


1 


0110 


WS 


W 


Save LSW of result in WR + 1 



tThe number of cycles Is specified in the count field of the opcode. 
'The new mask controls Interrupts. 
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TABLE 19 - INSTRUCTION EXECUTION SEQUENCES (CONTINUED) 



NUMBER 


BUS 




READ 






OF 


STATUS 




OR 






CYCLES 


CODE 


NAME 


WRITE 


COMMENT 




MPYS 


Ns 




<SRC> 




Fetch source operand 




1 


1(X)1 


AUMS 








1 


0110 


WS 


R 


Fetch dest'n operand from WR 




19 


1001 


AUMS 




Series of 19 consecutive AUMS cycles 




1 


0110 


WS 


W 


Save MSW of result in WR 




1 


0011 


lAQ 


R 


Fetch next instruction 




1 


0110 


WS 


W 


Save LSW of result in WR + 1 




RTWP (return from subroutine in nialn memory) 


1 


1001 


AUMS 








1 


0110 


WS 


R 


Fetch new PC from WR14 




1 


0110 


WS 


R 


Fetch new ST from WR15 




1 


0110 


WS 


R 


Fetch new WP from WR13 




2 


1001 


AUMS 




Series of 2 consecutive AUMS cycles 




1 


1101 


ST 




Output new ST on address bus 




1 


0011 


lAQ 


R 


Prefetch next instruction 




1 


1100 


WP 




Output new WP on address bus 




RTWP (return from using opcodes >380, >382, or >384 


5 


1001 


AUMS 




Series of 5 consecutive AUMS cycles 




1 


0011 


lAQ 


R 


Prefetch next instruction 




1 


1001 


AUMS 








Jump Instructions 






1 


1001 


AUMS 








1 


0011 


lAQ 


R 


Prefetch next instruction 




1 


1001 


AUMS 
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TABLE 19 - INS'mUCTION EXECUTION SEQUENCES (CONTINUED) 



NUMBER 


BUS 




READ 




OF 


STATUS 




OR 




CYCLES 


CODE 


NAME 


WRITE 


COMMENT 


SLAM, SRAM 


1 


0010 


lOP 


R 


Fetch second word of opcode 


1 


1001 


AUMS 






Ns 




<SRC> 




Fetch MSW of source operand 


IF SHIFT COUNT IS ZERO, GO TO LABEL 1 






2 


1001 


AUMS 




Series of 2 consecutive AUMS cycles 


1 


0001* 


SOP* 


R 


Fetch LSW of source operand 


2 


1001 


AUMS 




Series of 2 consecutive AUMS cycles 


CNTt 


1001 


AUMS 




Repeat shift operation 


1 


0001* 


SOP* 


W 


Save LSW of source operand 


1 


0011 


lAQ 


R 


Fetch next instruction 


1 


0001* 


SOP* 


W 


Save MSW of source operand 


LABEL 1 : (GO HERE IF SHIFT COUNT IS ZERO) 






1 


1001 


AUMS 






1 


0110 


WS 


R 


Fetch shift count in WRO 


2 


1001 


AUMS 




Series of 2 consecutive AUMS cycles 


1 
1 


0001* 
1001 


SOP* 
AUMS 


R 


Read LSW of source operand 


IF SHIFT COUNT IN RO IS ZERO, GO TO LABEL 2 






1 


1001 


AUMS 






CNTt 


lOOIt 


AUMSt 




Repeat shift operation until done 


1 


0001* 


SOP* 


W 


Write LSW of result to source address 


1 


0011 


lAQ 


R 


Fetch next instruction 


1 


0001* 


SOP* 


W 


Write MSW of result to source address 


LABEL 2: (GO HERE IF SHIFT COUNT IN WRO IS ZERO) 






1 


1001 


AUMS 






1 


0001* 


SOP* 


W 


Write LSW of result to source address 


1 


0011 


lAQ 


R 


Prefetch next instruction 


1 


0001* 


SOP* 


W 


Write MSW of result to source address 



'Substitute WS bus status code if operand Is in workspace register. 
tNumber of cycles Is equal to shift count. 
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TABLE 19 - INSTRUCTION EXECUTION SEQUENCES (CONTINUED) 



NUMBER 


BUS 




READ 






OF 


STATUS 




OR 






CYCLES 


CODE 


NAME 


WRITE 


COMMENT 




STCR (parallel store CRU) 


Nst 






Fetch source operand if byte transfer 




NOTE: SOURCE OPERAND IS NOT FETCHED IF WORD TRANSFER 






1 


0110 


ws 


R 


Read I/O base address from WR12 




2 


1001 


AUMS 




Series of 2 consecutive AUMS cycles 




2 


1011 


I/O 


R 


I/O cycle is minimum 2 states long 




2 


1001 


AUMS 




Series of 2 consecutive AUMS cycles 




1 


oooit 


SOPt 


W 


Save result in source address 




1 


0011 


lAQ 


R 


Prefetch next instruction 




1 


1001 1 


NOPt 




Increment WR12 if necessary 




STCR (bit-serial store CRU) 


Nst 








Fetch source operand if byte transfer 




1 


0110 


WS 


R 


Fetch I/O base address from WR12 




5 


1001 


AUMS 




Series of 5 consecutive AUMS cycles 




2§CNT* 


1011 


I/O 


R 


I/O read takes min. 2 states/bit 




3 


1001 


AUMS 




Series of 3 consecutive AUMS cycles 




IF 8 OR 16 BITS TRANSFERRED, GO TO 


LABEL 1 








? 


1001 


AUMS 




Repeat cycle 8-N for byte or 16-N for word, where N 
number of bits 


= 


LABEL 1: 












1 


0011 


lAQ 


R 


Fetch next instruction 




1 


00011 


SOP§ 


W 


Save result in source address 




SBO, SBZ (single-bit CRU instructions) 


1 


1001 


AUMS 








1 


0110 


WS 


R 


Fetch I/O base address from WR12 




1 


1001 


AUMS 








2 


1011 


I/O 


W 


I/O cycle is minimum 2 states long 




1 


0011 


lAQ 


R 


Fetch next instruction 




1 


1001 


AUMS 









'Number of cycles is equal to count field from STCR opcode. 

tSubstitute WS bus status code If WR 12 is post-incremented by 2. 

tif source operand Is word rather than byte, fetch of operand Is replaced by AUMS cycle. 

§Substltute WS bus status code If operand is in workspace register. 
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TABLE 19 - INSTRUCTION EXECUTION SEQUENCES (CONTINUED) 



NUMBER 


BUS 




READ 




OF 


STATUS 




OR 




CYCLES 


CODE 


NAME 


WRITE 


COMMENT 


TB 


1 


1001 


AUMS 






1 


0110 


ws 


R 


Fetch I/O base address from WR12 


1 


1001 


AUMS 






2 


1011 


I/O 


R 


I/O cycle is minimum 2 states long 


1 


0011 


lAQ 


R 


Fetch next instruction 


1 


1001 


AUMS 






TMB, TOMB, TSMB {source operand in v 


workspace register) 






1 


0010 


lOP 


R 


Fetch second word of instruction 


1 


0110 


WS 


R 


Fetch source operand from WR 


2 


1001 


AUMS 




Series of 2 consecutive AUMS cycles 


Bit displacement''' 


1001 


AUMS 




Shift target bit into position 


2 


1001 


AUMS 




Series of 2 consecutive AUMS cycles 


1 6-bit displacement* 


1001 


AUMS 




Restore shifted bit to original position 


1 


1001 


AUMS 






1 


0110 


WS 


W 


Write result to WR 


1 


0011 


lAQ 


R 


Fetch next instruction 


1 


1001 


AUMS 






TMB, TOMB, TSMB (non-register source 


operand) 






1 


0010 


lOP 


R 


Fetch second word of instruction 


Ns-1 




<SRC> 




Get source address (see next cycle) 


1 


0000 


SOPL 


R 


Fetch source with MPILCK active 


2 


1000 


AUMSL 




Sffl-ies of 2 consecutive AUMSL cycles 


Bit displacement^ 


1000 


AUMSL 




Shift target bit into position 


2 


1000 


AUMSL 




Series of 2 consecutive AUMSL cycles 


1 6-bit displacement* 


1000 


AUMSL 




R^tore shifted bit to original position 


1 


1000 


AUMSL 






1 


0001 


SOP 


W 


Save results and deactivate MPILCK 


1 


0011 


lAQ 


R 


Prefetch next instruction 


1 


1001 


AUMS 







^ Number of cycles is equal to the bit number plus one. 
* Number of cycles is equal to 1 6 minus the bit number. 
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TABLE 19 - INSTRUCTION EXECUTION SEQUENCES (CONTINUED) 



NUMBER 


BUS 




READ 




OF 


STATUS 




OR 




CYCLES 


CODE 


NAME 


WRITE 


COMMENT 


X 

Ns 




<SRC> 




Fetch source operand (target opcode) 


1 


1001 


AUMS 




Execute target opcode 


STST, STWP 


1 


1001 


AUMS 






1 


0011 


lAQ 


R 


Fetch next instruction 


1 


0110 


WS 


W 


Save result in WR 


XOP 


Ns-1 




<SRC> 




Get source operand address (see next) 




1001 


AUMS 




Block fetch of source operand 




1101 


ST 




Output all zeros on address bus 




1001 


AUMS 








0101 


INTA 


R 


Fetch new WP from vector 




1001 


AUMS 








1100 


WP 




Output new WP on address bus 




1001 


AUMS 








Olio 


WS 


W 


Save source address in WR1 1 




0101 


INTA 


R 


Fetch new PC from vector 




0110 


WS 


W 


SaveotdWPinWRIS 




Olio 


WS 


W 


SaveoldPCinWR14 




0110 


WS 


W 


SaveoWSTinWRIS 




0011 


lAQ 


R 


Fetch next instruction 




1001 


AUMS 






XOR 


Ns 




<SRC> 




Fetch source operand 


1 


0110 


WS 


R 


Fetch dest'n operand from WR 


1 


0011 


lAQ 


R 


Fetch next instruction 


1 


0110 


WS 


W 
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TABLE 19 - INSTRUCTION EXECUTION SEQUENCES (CONCLUDED) 



NUMBER 


BUS 




READ 






OF 


STATUS 




OR 






CYCLES 


CODE 


NAME 


WRITE 


COMMENT 




EVAD (This instruction is available only in 


Macrostore) 








Ns 




<SRC>* 




Fetch source operand 




1 


1001 


AUMS 








1 


1001 


AUMS 




Save Macrostore PC in WR4 of Macrostore 




1 


1001 


AUMS 




Fetch user's PC from WR14 of Macrostore 




2 


1001 


AUMS 




Series of 2 consecutive AUMS cycles 




IF TARGET OPCODE SOURCE ADORES 


S IS •R + , GOTO LABEL 1 






Ns-1 




<SRC> 




Get source address for target word 




GO TO LABEL 2 












LABEL 1: 












1 


0110 


WS 


R 


Fetch source address from user's WR 




2 


1001 


AUMS 




Series of 2 consecutive AUMS cycles 




1 


1001 


AUMS 




Save address of user's WR in WR10 




1 


1001 


AUMS 








LABEL 2: 












IF TARGET OPCODE DESTINATION AD 


3RESSIS*R + ,G0 


TO LABEL 3 






Nd-1 




<DST> 




Get dest'n address for target word 




GO TO LABEL 4 












LABELS: 












1 


0110 


WS 


R 


Fetch dest'n address from user's WR 




1 


1001 


AUMS 




Save address of user's WR in WR9 




LABEL 4: 












3 


1001 


AUMS 




Series of 3 consecutive AUMS cycles 




1 


1001 


AUMS 




Save updated user PC In WR14 of Macrostore 




1 


1001 


AUMS 




Restore Macrostore PC 




2 


1001 


AUMS 




Series of 2 consecutive AUMS cycles 




1 


1001 


AUMS 




Save dest'n address in WR7 of Macrostore 




1 


1001 


AUMS 




Fetch next instruction 




1 


1001 


AUMS 




Save source address in WR8 of Macrostore 





'All cycles output AUMS bus status code. 



90 



TABLE 20 - INTERRUPT AND MACROSTQRE TRAP SEQUENCES 



NUMBER 


BUS 




READ 




OF 


STATUS 




OR 




CYCLES 


CODE 


NAME 


WRITE 


COMMENT 


INTERRUPTS 








2 


1001 


AUMS 




Series of 2 consecutive AUMS cycles 


1 


1101 


ST 




Output aH zeros on address bus 


1 


0101 


INTA 


R 


Fetch new WP from interrupt vector 


2 


1001 


AUMS 




Series of 2 consecutive AUMS cycles 


1 


0101 


INTA 


R 


Fetch new PC from interrupt vector 


1 


1100 


WP 




Output new WP on address bus 


1 


0110 


WS 


W 


SaveoldWPinWRIS 


1 


0110 


WS 


W 


SaveoldPCinWR14 


1 


0110 


WS 


W 


SaveoldSTinWRIS 


1 


0011 


lAQ 


R 


Fetch next instruction 


1 


1001 


AUMS 






TRAP TO MACROSTORE (MID trap) 


1 


1001 


AUMS 






1 


1110 


MID 




Check for attached processor 


1 


1001 


AUMS 






1 


1001 


AUMS 




Save contents of main IR in WR5 


1 


1001 


AUMS 






1 


1001 


AUMS 




If MID trap is due to 2nd word of instruction, save PC-2 in WR 14 


1 


1001 


AUMS 




Save IDS and LDD flags and first word of 32-bit opcode in WR3 


1 


1001 


AUMS 




Read Macrostore PC from vector 


1 


1001 


AUMS 






1 


1001 


AUMS 




Save user's WP in WR13 


1 


1001 


AUMS 




Save user's PC in WR14 


1 


1001 


AUMS 




Save user's ST in WR 1 5 


2 


1001 


AUMS 




Series of 2 consecutive AUMS cycles 
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TABLE 21 - ATTACHED PROCESSOR INTERFACE SEQUENCES 



NUMBER 


BUS 




READ 




OF 


STATUS 




OR 




CYCLES 


CODE 


NAME 


WRITE 


COMMENT 


99000 TRANSFERS CONTROL TO ATTACHED PROCESSOR {MID trap) 


1 


1001 


AUMS 






1 


1110 


MID 




Check for attached processor 


2 


1001 


AUMS 




Series of 2 consecutive AUMS cycles 


1 


1101 


ST 




Output all zeros on address bus 


1 


0101 


INTA 


R 


Fetch WP from level-2 vector 


3 


1001 


AUMS 




Series of 3 consecutive AUMS cycles 


1 


1100 


WP 




Output new WP on address bus 


1 


0110 


WS 


W 


SaveoldWPinWR13 


1 


0110 


WS 


W 


SaveoldPCinWR14 


1 


0110 


WS 


W 


SaveoWSTinWRIS 


1 


nil 


HOLDA 




Release bus to attached processor 


ATTACHED PROCESSOR RETURNS CONTROL TO 99000 


1 


1111 


HOLDA 




Last state of hold cycle 


1 


0110 


WS 


R 


Fetch new PC from WR 14 


1 


0110 


WS 


R 


Fetch new ST from WR 15 


1 


0110 


WS 


R 


Fetch new WP from WR 13 


1 


1101 


ST 




Output new ST on address bus 


1 


0011 


lAQ 


R 


Fetch next instruction 


1 


1100 


WP 




Output new WP on address bus 



ADVANCE INFORMATION 

This document contains information on 
a new product. Specifications are subject 
to change without notice. 
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1 1 TMS99 1 05A/TMS99 1 1 0A PRELIMINARY ELECTRICAL SPECIFICATIONS 

11.1 ABSOLUTE MAXIMUM RATINGS OVER OPERATING FREE-AIR TEMPERATURE RANGE (UNLESS OTHERWISE 

NOTED) t 

Supply voltage, Vcc <see Note 1 ) -0.3 to 7 V 

All input voltages -0.3 to 20 V 

Output voltages -0,3 to 7 V 

Continuous power dissipation . • ' y"" myri 

Operating free-air temperature 



0*>Cto70''C 



f Stresses beyond those listed under"Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and func- 
tional operation of the device at these or any other conditions beyond those indicated in the "Recommended Operating Conditions" section of this 
specification is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability. 

Note 1 : All voltage values are wrth respect to Vss 

11.2 RECOMMENDED OPERATING CONDITIONS 



PARAMETER 



Supply voltage, Vqc 



Supply voltage, Vss 



High-level input voltage, V|h (all inputs except CLKIN) 
High-level input voltage, V|h (CLKIN) 



Low-ieveT input voltage, V|l (all inputs except CLKIN) 



Low-level input voltage, V|l (CLKIN) 



High-level output current, Iqh (All outputs) 



Low-level output current, Iql (a" outputs) 



Operating free-air temperature, Ta 



MIN NOM MAX 



4.75 



5.25 



VCC + ^ 



3.5 



Vcc + 1 



-1 



0.8 



0.2 



400 
~2^ 



70 



♦output current of 2 mA is sufficient to drive 5 low-power Schottky TTL loads or 10 advanced low-power Schottky TTL loads (worst case). 



UNITS 



mA 



mA 



11.3 ELECTRICAL CHARACTERISTICS OVER RECOMMENDED FREE-AIR TEMPERATURE (UNLESS 
OTHERWISE NOTED) 



PARAMETER 


TEST CONDITIONS^ 


MIN TYP^ MAX 


UNIT 


Vqh High-level output voltage 


Vcc = MIN, Iql = MAX 


2.4 


V 


Low-level output voltage 
^O*- all except BST(1 -3), R/W, MEM 


Vcc = MIN, l0L = MAX 


0.5 


V 


Low-level output voltage, 
^°'- (BST(1-3), R/W, MEM 


Vcc = MIN, Iql = MAX 


0.6 


V 


Tristate (high-impedance) output 
^ current (off) 


Vcc = MAX 


Vo = 2.4V 


20 


jiA 


Vo=0.4V 


-20 


l| Input current 


V|=VsstoVcc 


20 


yA 


Ice Supply current 


Vcc = MAX 


120 


mA 


Input capacitance (all inputs 
' except address/data lines) 


f = 1 MHz, all other pins at V 


15 


pF 


Cdb Address/data line capacitance 


25 


pl- 


Output capacitance (except 
Co 
" address/data lines) 






10 15 


PF 



tFor conditions shown as MIN or MAX, use the appropriate value specified under recommended operating conditions. 
tAI typical values are at V^c = 5 V, T/^ = 25°C. 

11.4 CLOCK CHARACTERISTICS 

The TMS99000 has an internal oscillator and 4-phase clock generator controlled by an external crystal or resistor-capacitor 
combination. Alternatively, the user can directly inject a frequency source into the XTAL1 input. The period of the 
frequency source must be one-fourth the desired machine state time. 

11.4.1 I nternal Oscillator 

The internal oscillator is enabled by connecting a crystal across XTAL1 and XTAL2. The machine state time, t^, is four 
times the crystal oscillator period, 1 /f,. The crystal should be a fundamental series-resonant type. Figure 33 presents the 
circuit configuration for this mode of operation. 

ADVANCE INFORMATION 

93 This document contains information on 

a new product. Specifications are subject 
to change without notice. 



TMS99105A 

TMfiQCIIinA 



XTAL1/CLKIN 



XTAL2 



CI 



crystal 



m 



C2 



/77 



NOTES : 1 . The crystal should be a fundamental series^esonant type operating at four times the machine state frequency. 
2. CI and C2 represent the total capacitance on these pins, including strays and parasitics. 

FIGURE 33 - INTERNAL OSCILLATOR 



PARAMETER 



Crystal frequency, fy 



C1,C2 



TEST CONDITIONS 



0-70 °C 



0-70 °C 



MIN TYP MAX 



24 



UNIT 



MHz 



PF 



11.4.2 External Clock 



An external clock of frequency f^ may be connected to the XTAL1/CLKIN in place of a crystal or RC combination. The 
period of the CLKOUT output signal will be 4/f^. Figure 34 shows the circuit configuration when an external clock is used. 



PARAMETER 



fext 



External source frequency 



'c* 



CLKIN cycle time 



tr+ 



CLKIN rise time (see Note 1 ) 



tf^, 



CLKIN fall time (see Note t ) 



%H1 



CLKIN high-level pulse width 



^wLI 



CLKIN low-level pulse width 



MIN 



NOM 



MAX 



12 



24 



41.25 



83.33 



10 



10 



tc(/»/2-tr<^ 



W2-tf,i, 



UNIT 



MHz 



Note 1 : CLKIN rise and fall times are a function of V|h and V|l. For the times shown the V|h and V|l levels are as given under "Recommended Operating Conditions." If a 
maximum 5 ns rise and fall time can be achieved, then the 7,^ and V^ levels may be standard levete of 2.4 V and 0.4 V respectively. 



+ 5 V 



XTAL1 




TMS99105A 
TMS99110A 



FIGURE 34 - EXTERNAL OSCILLATOR 



ADVANCE INFORMATION 

This document contains information on 
a new product. Specifications are subject 
to change without notice. 
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11.5 



TIMING REQUIREMENTS OVER RECOMMENDED OPERATING CONDITIONS 



PARAMETER 


MIN NOM MAX 


UNIT 


tsul 


READY setup time prior to falling edge of CLKOUT 


35 


ns 


thi 


READY hold time after falling edge of CLKOUT 





ns 


tsu2 


Data setup time prior to falling edge of CLKOUT 


30 


ns 


th2 


Data hold time after falling edge of CLKOUT 





ns 


tsu3 


INTREQ, RESET, APP setup time prior to falling edge of CLKOUT 


40 


ns 


tsu4 


HOLD setup time prior to falling edge of CLKOUT 


80 


ns 


th3 


INTREQ, RESET, APP, HOLD hold time after falling edge of CLKOUT 


15 


ns 


tacc 


Access time, address valid to data valid at data setup time 


3tc2/4-40 


ns 


tded 


RD low until valid data required 


tc2/2-63 


ns 



11.6 



SWITCHING CHARACTERISTICS OVER RECOMMENDED OPERATING CONDITIONS 



PARAMETER 


TEST CONOmONS 


MIN 


TYP 


MAX 


UNIT 


tc2 


CLKOUT cycle time (f(x) = crystal freq) 


Cl = 100 pF 
(See Figure 35) 


4tc1 or 4/fx 


ns 


tr2 


CLKOUT rise time 




10 


15 


ns 


tf2 


CLKOUT fall time 




10 


15 


ns 


twH2 


CLKOUT high-level pulse width 


tc2/2-tr2 


ns 


twL2 


CLKOUT low-level pulse width 


tc2/2-tf2 


ns 


twH3 


ALATCH pulse width high 


tc2/4-tr2 


ns 


tdl 


Delay time, reference line to ALATCH low 


tc2/4 + 13 


ns 


td2 


Delay time, ref line to ALATCH high 




11 


15 


ns 


td3 


Delay time, ref line to MEM, BST, R/W 
address, PSEL valid 




13 


15 


ns 


td4 


Delay time, ALATCH low to address, PSEL 
invalid 


10 


15 


20 


ns 


tdzl 


Delay time, ALATCH to address hi-z 


20 


30 


35 


ns 


td5 


Delay time, ref line to start of WE invalid 


tc2/4 


ns 


td6 


Delay time, ALATCH low to start of 'RD invalid 


10 


24 


30 


ns 


td7 


Delay time, CLKOUT low to WE, RD high 




15 


30 


ns 


td8 


Delay time, ALATCH low to data valid 


20 


30 


35 


ns 


td9 


Delay time, ref line to WE valid 




tc2/4+13 


tc2/4 + 20 


ns 


tdlO 


Delay time, WE/IOCLK high to data invalid 


tc2/4-30 


ns 


tdll 


Delay time, CLKOUT low to data, PSEL, 
BST, MEM, R/W invalid 


tc2/4 + 5 


ns 


td12 


Delay time CLKOUT low to WE/IOCLK, RD 
inactive 





ns 


tdrde 


Delay time ref line to RD low 


tc2/4 + 40 


ns 


tdz2 


Delay time, ref line to R/W hi-z 


tc2/4 + 25 


ns 


tdz3 


Delay time, ref line to ALATCH hi-z 


tc2/4 + 25 


ns 


td(rav) 


Delay time, ref line to ALATCH invalid 


tc2/4 


ns 


td13 


Delay time, ALATCH low to address, MEM, 
BST, r5, WE, R/W invalid 


10 


ns 


td14 


Delay time ref line to address, MEM, BST, 
RD, WR, R/W invalid 


tc2/4 + 20 


ns 
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ADVANCE INFORMATION 

This document contains information on 
a new product. Specifications are subject 
to change without notice. 



Test point 
O 



From output 
under test 




Diodes 



FIGURE 35 - SWITCHING TIMES LOAD CIRCUIT 
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CLKIN 


1 1^ tf2 
1 
\^ 


— tw 


V 

fL2' 


-JU- II 

J tJ 

II M 

-►|l^tr2 
II 




^ J 
twLI 


1 


CLKOUT 


1 






1 




K 


1 
1 




1 


1 
1 


^1 






tc2 


1 
1 

•"! 



NOTES: (1 ) There is no time relationship implied or specified between the input clock and the output cloclc. 
(2) All timing reference points are 10% and 90% points- 

FIGURE 36 - CLOCK TIMING PARAMETERS 
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COMMON SIGNALS 

k»-tc2/4— ^ 

■i I 

CLKOUT \ i 



h i n clock cycles 
*r(n- 1 wait states) 



/ 



w>- 



■tdl- 



1v 



ALATCH I 

I 



/ — u 



I I 

I ' 

h 



■trO 






■tf2 



READY 



. yyyyyymyyxxyi ..ixvymy 



•*-tsu1 
I s 



|*-td3 I 



BST(1-3). 



MEM,R/W 



t 



1 I 



•-thi 



valid code | | 



MEMORY READ CYCLE 



! 1^ 



■tacc- 



ADDR/ 
DATA 



RD 



I I 



ic 



'r Tl* *^'' ''■ 



' I [• -htdzl 

^;; ^ address j ^hi-z— )p^;rV- -x;;^ 

, l*-td6-H l**ded-^ U-td7-i^ 



7 



I 

■trde 



td12 



7 



WE / I 
I 



MEMORY WRITE CYCLE 



tdS- 
td4 



I— I 



■tdll- 



ADDR/ 
DATA 



RD 



[•-4-td3 I I 

lyf address jF 



I 



l^tdlO- 



valid data 



ic 



7 



•td9' 



i 



U-td7 



WE 



INTERNAL ALU CYCLE 



7T 

.1 



■td5- 



^ 






td12 



ADDR/ 
DATA 



RD.WE 



I jC undefined V 



undefined 



x: 



7 



reference 
line 

HGURE 37 - MEMORY AND INTERNAL CYCLE TIMING PARAMETERS 

All timing reference points are 1 0% and 90% points. 
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COMMON SIGNALS 

CLKOUT \ I 



/ 



|^tc2/4-ii| 



. ■ n clock cycles 

" *l (n wait states) 



td2 



AUVTCH 



READY 




twH3-|« M 



-tf2 



BSTH 



1-3) "tntI' 

R/W _JJ$j, 



. td3 ' 
I i I 



I/O INPUT CYCLE 



ADDR/ 
DATA 






td4— ^ I 






RD 



I td6-t*- 



:^ 



WE/IOCLK 
I/O OUTPUT CYCLE 



ADDR/ 
DATA 



Il){ 



td4 



address 



Ul-td3 '^^'^S 



Jv- 



RD 



WE/IOCLK 



■tea- 



reference 
line 



/ % 



r 



|«~tsu1- 



thi-«Jh— 



valid code 



I 



k-tdl 



^ 



I 

I 

• hi-z 
I 



th2-H 
k-tsu2-^ 



I > * 1 td7 



-tc2+tded- 



4 



I valid data 



|^td5-H 
reference 
line 



'^ 



— JK-*d12 



l«-td11-^ 
t'dIO h •\ 



ii 



td9 — H I* — T *d7 

i^i ^ 



l*-tdi: 



FIGURE 38 - I/O CYCLE TIMING PARAMETERS 



All timing reference points are 10% and 90% points. 
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r 



■3tc2/4- 



CLKOUT 



/ 



tsuS-^- 



aM %i 






TaRT 
input 



NMIAPP 



reference 
line 



th3 




^ 



NOTE: The CLKOUT edge at which each of the input signals is sampled is defined in the section pertaining to that signal. 



FIGURE 39 - INTERRUPT. HOLD AND APP TIMING PARAMETERS 



CLKOUT 



ALATGH 



BSTd-S), 



MEM, RD, I / 

WE/CRUCLK,_ I / 
ADDRESS, R/W | 



u 



reference 
line 



tc2- 



/ 



I h — tdzi 



I 



>-tdl3-^ 
td14 A 



^ 



td22' 



\ 



hi-z 



/ 



■tdz3- 



j* trav ' 



>(.h,-.- 



reference 
line 



FIGURE 40 - HOLD CYCLE TIMING PARAMETERS 

All timing reference points are 1 0% and 90% points. 
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CLKOUT 



/ 



ALATCH 



hi-z 



/ 



ME M, BST n-3). 
WE/IOCLK, 
RD, R/W. 
ADDRESS 



hi-Z 



^td2-#» 



< 



'^tda^l 



reference 
line 



valid 



FIGURE 40 - HOLD CYCLE TUMING PARAMETERS (CONCLUDED) 



All timing reference points are 1 0% and 90% points. 
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1 2. TMS99000 MECHANICAL SPECIFICATIONS 

1 2.1 TMS99105A/TMS991 10A - 40-PIN CERAMIC PACKAGE 




. 15,24 ±0.254. 
(0.600 ±0.010) 



0.508 (0.020) MIN 



0,254 (0.010) NOM- 



SEATING 

"plane 



4' 



0,457 ±0.076. 
(0.01 8 ±0.003} 




m 



PIN SPACING 2,54 (0.100) T.P. 

(SMNotea) 1,27 ±0,254 . 

(0.050 ±0.010) 



i 



I MAX 



150 ± 0.030) 



.813 (0.032) NOM 

- 1,27 ±0,508 
(0.050 ±0.020) 



NOTES: a. Each pin centarHne is locatad within 0,254 (0.010) of its tnia kmgitudhMl position, 
b. AN Nnaar dimensions ara in mafimaters and paranthaticaly in inchas. inch dimansions 
govern. 



1 2.2 TMS99 1 05A/TMS99 11 OA - 40-PIN PLASTIC PACKAGE 




\_ 15,24 ±0,254 J 
■^(0.600 ±0.010)"^ 



I— ILJI-JI_IL-JLJI_II-JLJI-JLJLJI_J1— ILJLJI-JI— ILJLJ^ 



0,508 (0.020) 
MIN 



105 
90 

0.279 ± 0.076 
(0.011 ± 0.0031 



\- SEATING PLANE 

0.457 ±0,076 
01 8 ±0.003) 



nr ' 




PIN SPACING 2.54 (0.100) T.P 
(Sea Note a) 



5,08 (0.200) MAX 

3.17 (0.125) MIN 

838 (0.033) MIN 

2.41 (0.095) 
~ 1,40(0.055) 



1,52 (0.060) NOM- 



NOTES: a. Each pin centarHne is located within 0,254 (0.010) of its true kmgitudinal position. 

b. An linear dimensions are in millimeters and parentheticaly in inchas. Inch dimensions 
govern. 
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APPENDIX A 
TMS99105A SUPPLEMENT 
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A. TMS99105A DESCRIPTION 

The TMS99105A is the basic rnember of the TMS99000 mjcrc^rccesscr fsmih'. Th'' jmcooi dra ^t*^,^ +k» «».»» 
features as described in Sections 1 through Section 1 2. The only feature not implemented on the TMS991 05A is on- 
chip Macrostore. However, external Macrostore may be utilized for user-implemented functions and instructions. 

A.1 TMS99105A MACROSTORE OPERATION 

The TMS99105A may utilize external Macrostore by placing the TMS99105A in prototyping mode (see Section 
7.2.4.2). If no external Macrostore is to be implemented in the system. It is recommended that the TMS991 05A be 
placed in baseline mode (Section 7.2.4.3). If no external Macrostore is implemented on the TMS991 05A and the stan- 
dard mode or prototyping mode is selected, the occurrence of a MID opcode will result in indeterminate operation. 
This is due to the fact that a Macrostore vector will occur to non-existent Macrostore memory (see Section 7.3) 
and potentially cause a system lockup. 
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APPENDIX B 
TMS99110A SUPPLEMENT 
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B TMS99 1 1 0A DESCRIPTION 

The TmS991 IOA 16-bit microprocessor is a powerful memiaer of the TMSSSOOO famiiy that impiements 12 single 
precision floating point instructions, 2 memory mapper control instructions and a 32 X 32 signed integer multiply in- 
struction. These powerful instruction set enhancements are implemented via the on-chip Macrostore memory space. 
They are additions to the instruction set described in Section 1 0. 

B . 1 TMS99 1 1 0A MACROSTORE OPERATION 

With the instruction set extensions of the TMS99110A implemented in Macrostore, it is required that the 
TMS991 IDA be generated in standard mode (see Section 7.2.4.1). If either the prototyping mode or baseline 
mode of operation is selected, the instruction set extensions described in this section will not be operational. 

B.2 TMS99 1 1 DA INSTRUCTION SET EXTENSION SUMMARY 

The TMS99 1 1 0A implements the instructions listed Table B. 1 in addition to those listed in Section 1 0. Note that these 
instructions are operational only when the TMS991 IOA is operated in the standard mode. 

TABLE B.I - TMS99110A INSTRUCTION SET EXTENSION SUMMARY 



MNEMONIC 


DESCRIPTION 


OPERATION* 


LDD 


Long Distance Source 


Update internal LDD flag 


LDS 


Long Distance Destination 


Update internal LDS flag 


AR 


Add Real 


FPAC-l-(SA,SA-h2) - FPAC 


SR 


Subtract Real 


FPAC - (SA,SA + 2) - FPAC 


MR 


Multiply Real 


(SA,SA + 2) • FPAC -FPAC 


DR 


Divide Real 


FPAC / (SA,SA + 2) - FPAC 


LR 


Load Real 


(SA,SA-h2)-FPAC 


STR 


Store Real 


FPAC-*(SA,SA + 2) 


NEGR 


Negate Real 


- FPAC - FPAC 


OR 


Compare Real 


(SA,SA-h2) - (DA,DA + 2) set status 


CIR 


Convert Integer to Real 


Convert (SA) - FPAC 


CER 


Convert Extended Integer to Real 


Convert FPAC - FPAC 


CRI 


Convert Real to Integer 


Convert FPAC to integer -► FPAC 


ORE 


Convert Real to Extended Integer 


Convert FPAC to ex. integer -* FPAC 


MMt 


Multiply Multiple (32x32) 


(SA,SA + 2) • (DA,DA-l-2)- 
(DA,DA-2,DA-(-4,DA + 6 



•Floating point accumulator (FPAC) is designated as workspace registers and 1 of the current workspace. 
^MM is not a ftoating point operation but is an addition to the TMS991 IDA instrucfron set. 

B .3 TMS99 1 1 0A MEMORY MAPPER CONTROL INSTRUCTIONS 

The LDD and LDS instructions are provided for use in controlling a 16-register memory map file. These instructions are 
implemented on the 991 10 only. 

These mapper instructions are intended to support the use of the TIM99610 (SN74LS610) memory mapper (see the 
SN74LS610 data sheet). 



General 
Format 



12 3 


4 5 6 7 8 


9 10 11 12 13 14 


15 


1 


OPCODE 


10 


1 








MNEMONIC 


OPCODE 
0123 4567 89 


MEANING 




LDS 
LDD 


0000 0111 10 
0000 0111 11 


Long Distance Source 
Long Distance Destination 





The LDD and LDS instructions permit data to be accessed through the user's memory map while in the supervisor 
mode. The PSEL pin will be inverted during the source (if LDS) or destination (if LDD) operand access cycles of the 
following instruction, unless the addressing mode is register direct. When register direct addressing (Ts = or 
Td = 0) is used for the source or destination operand fetch, PSEL is not altered. 
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Listed below are the effects when an LDD or LDS instruction follows an LDS or LDD instruction. In general, only the first 
two cases, LDD followed by LDS or LDS followed by LDD, are considered useful: 

LDD — LDS: Both the source and destination memory cycles of the instruction that follows are long distance. 

LDS - LDD: Same as LDD - LDS. 

LDS - LDS: The first LDS has no effect; the source memory cycles of the instruction that follow are long distance. 

LDD - LDD: The first LDD has no effect; the destination memory cycles of the instruction that follow are long 

distance. 

interrupts are inhibited until after the next instruction. 

An attempt to execute a long-distance instruction while in user mode (ST7 = 1) will be flagged as a privileged opcode 
violation. 

The LDS or LDD instruction has no effect if the source or destination addressing mode of the target instruction is 
workspace register direct. 

If the instruction to be long distanced is interruptible, the long distance information can be recovered upon return from the 
interrupt. An example of an interruptible instruction is a block move with multiple source and destination operands to 
which long distancing is applied. Typically, a checkpoint or loop count register keeps track of the number of moves 
completed. If long distancing is not applied to either operand, the normal procedure, when an interrupt occurs, is to store 
the loop count and other pertinent instruction status in a checkpoint register and decrement the program counter. After 
the interrupt is serviced, execution continues from where it stopped. After the instruction is completed, the check point 
register is set to - 1 or some other value to indicate that the instruction will be executed for the first time when it is next 
encountered. 

Several features have been incorporated into the LDD and LDS instructions to facilitate recovery from an interrupted 
instruction when an LDD and/or an LDD instruction is active. Both the LDD and the LDS instructions save the address 
plus 2 (main memory) of the first LDD or LDS in a possible sequence of LDD s and/or LDS s. Any Macrostore imple- 
mented instructions, which could be long distanced and interrupted, must not accidentally destroy this data. 

The three most significant bits of Macrostore location >0006 (WR3 if WP = 0) are long distance status information as 
shown in the following table. The fact that a long distance instruction is active may be determined by comparing the 
contents of >0006 to the value > EOOO. If the comparison is greater than or equal, then the long distance instruction is not 
active. 



LONG-DISTANCE 




FLAGS 




1 2 


MEANING 


1 1 1 


No long distancing in effect 


1 1 


Long distance source 


1 1 


Will never occur 


1 00 


Long distance source* 


1 1 


Long distance destination 


1 


Sequence: 1 ) LDD, 2) LDS (order is significant) 


00 1 


Will never occur 


000 


Sequence: 1) LDS, 2) LDD, or see Note.^ 



* A sequence of two LDS instructions has been encountered. If emulating the 990/1 2 version of LDS, the source operand access of the second LDS is controll- 
ed by the first LDS to be long distance. 

^ The sequence LDS, LDD, LDS has been encountered. If emulating the 990/1 2 version of LDD and LDS, then the source operand access of the LDD Is controll- 
ed by the first LDS to be long distance. 

The procedure for handling an interruptible instruction is relatively simple due to the information stored in locations > 0004 
and >0006 (WR2 and WR3 if WP = 0). When an interrupt is detected by using one of the jump on interrupt instructions, 
first do all necessary clean-up (such as updating the checkpoint register(s)), and compare Macrostore location >0006 to 
value > EOOO to determine if a long distance instruction was active. If no long distance is active, then load the contents of 
WR14 (used to return back to main memory) with the address of the start of the instruction. It may be necessary to save the 
contents of WR14 on entering Macrostore for this purpose because WR14 may be modified by executing the Macrostore 
routine or by an EVAD instruction. If a long distance is active, then the contents of location >0004 must be decremented 
by 2 and then loaded into WR14so that after returning with an RTWP ( > 0380), the PC will point to the start of the string of 
LDDs and/or LDSs. Since an interrupt caused the Macrostore routine to be exited, the interrupt vector will be taken 
immediately upon return to main memory via the RTWP instruction. Upon returning back to Macrostore from the 
interrupt(s), the PC will be initialized with the value at the time of Macrostore exit thus restarting the Macrostore routine. 
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The long-distance flags are automatically cleared if the exit from Macrostore is performed by executing the >0380 
or >0382 form of RTwP but are NOT cleared if >0384 is executed. The long-distance flags are also autematieai- 
ly cleared after the instruction following the LDD or LDS has been completed. Note that the long-distance flags 
have no effect on the PSEL output during Macrostore accesses. PSEL always represents the complemented value 
of STB when executing out of Macrostore memory space. Note if an SOP or OOP bus status code is output while 
in Macrostore, it will cause PSEL to flip if the corresponding LDD or LDS is active. 

B .4 TMS99 1 1 0A FLOATING POINT INSTRUCTIONS 

The floating point package of the TMS99110A provides floating point operations. The general method is to load the 
Floating Point Accumulator (FPAC - R0,R1 of user's workspace) with one operand, perform the desired operation, and 
then store the result found in the FPAC (see examples below). The floating point instructions are only available to the 
TMS99 1 1 0A when the processor is initialized in standard mode (Section 7.2.4. 1 ). When in prototyping mode, the ex- 
ecution of these opcodes will cause a trap to external Macrostore memory space for user defined opcodes. The user 
should avoid the use of these opcodes to prevent possible conflicts with future TMS991 1 0A floating point capability. 
When in baseline mode, execution of these opcodes will cause a level 2 illegal opcode interrupt. The following is the 
general format of a floating point number: 






1 2 


3 4 5 6 


7 


8 


9 10 


11 


12 


13 14 15 


Sgn 




Exponent 




1st Digit 


2nd Digit 




3rd Digit 


1 4th Digit 




5th Digit 


6th Digit 



Where: 

Sgn -♦ Sign of the number, = Pos, 1 = Neg 

Exponent — Exponent (radix 1 6) of the number +>40 (e.g., for the mantissa to be raised to the 2nd power, expo- 
nent would be 2+>40 = >42) 
Digits 1-6 ->- Mantissa of the number (in hex). 

NOTE: The TMS991 1 DA assumes tfie decimal point place to be prior to the first digit of the mantissa. It also assumes that the number is a floating pob' 
number and not zero, the first (ffgit is norv-zero. If a fkutirtg zero is to be represented, the exponent should also be cleared (set to 00). Otherwis 
errors couM result. 

TABLE B.2 - TMS991 10A FLOATING POMT FUNCTIONS 



AR 


Add Real 


to FPAC 


SR 


Subtract Real 


to FPAC 


MR 


Multiply Real 


to FPAC 


DR 


Divide Real 


to FPAC 


LR 


Load Real 


into FPAC 


STR 


Store Real 


from FPAC 


NEGR 


Negate Real 


in FPAC 


CR 


Compare Reals 


general source/dest 


CIR 


Convert Integer to Real 


general source to FPAC 


CER 


Convert Extended Integer to Real 


in FPAC 


CRI 


Convert Real to Integer 


in FPAC 


CRE 


Convert Real to Extended Integer 


in FPAC 


MM 


Multiply Multiple (32 bit Integer x 32 bit Integer = >64 bi general 
source/destinatk>n 





To perform a floating point function, the package uses RO and R1 of the user's workspace as a floating point accumulator. 
All floating point operations (except for MM and CR) use the FPAC. To load the accumulator use the LR instruction or 
manually move the desired operand into R0-R1 . To store a result, the STR instruction could be used or the number could 
be manually moved out (see example below). 

EXAMPLE 1 -ALTERNATE METHODS OF A SIMPLE OPERATION 



LR'R4 

ARR5 
STR @ANS 



Load FPAC 

Do Add Read 
Store Answer 



MOV *M,RQ 
MOV@2(R4),R0 

ARR5 

MOV RO,S>ANS 

M0VR1,@ANS + 2 
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EXAMPLE 2- A MORE INVOLVED FLOATING POINT SEQUENCE 

Suppose the following equation was to be evaluated and a 'lowest value calculated' parameter replaced if the result was 
even smaller. 

V1*(-V2- CONSTANT) 

V3 • ( V4 + 2.) 

Assuming the parameters were already off in memory some place, the following would be a possible solution. 
(Note addressing modes) 



LOOP 



LI 


R0,2 


CIR 


RO 


AR 


•R2 


MR 


•R3 + 


STR 


R8 


LR 


@CONST 


CER 




NEGR 




SR 


@0FFSET(R4) 


MR 


•R5 


OR 


R8 


CR 


R0,@L0W 


JGT 


LOOP 


STR 


@LOW 




(etc.etc.etc.) 



LOAD INTEGER 2 INTO FRAC 
CONVERT IT TO REAL 
ADD DENOMINATOR TERM V4 
MULTIPLY DENOMINATOR TERM V3 
STORE TEMP RESULT 

GET CONSTANT 

CONVERT EXTENDED INTEGER TO REAL 

NEGATE FPAC CONTENTS 

SUBTRACT NUMERATOR TERM V2 

MULTIPLY NUMERATOR TERM VI 

DO THE DIVISION 

COMPARE VS LOWEST 

JUMP IF NOT LOWER (OR EQUAL) 

STORE NEW LOWEST 



(hi word only) 
(register direct) 
(Indirect) 

(indirect auto-inc) 
(register direct) 

(symbolic) 
(FPAC content) 

(indexed) 
(indirect) 
(indirect) 
(direct & symbolic) 

(symbolic) 



B.4.1 Dual-Operand Floating Point Instructions with Multiple Addressing Modes for the Source Operand (99110A only) 

General 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 

Format: 






OPCODE 


Ts 


S 



The addressing mode for the source operand is determined by the Ts field. 



Ts 


S 


ADDRESSING MODE 


NOTES 



1 
2 
2 
3 


0,1 15 

0,1 15 



1,2 15 

1,2 15 


Workspace register 

Workspace register indirect 

Symbolic 

Indexed 

Workspace register indirect autoincrement 


1 
1,2 



NOTES: 1. Workspace register may not be used. 

2. The workspace register is incremented by 4. 









RESULT 


STATUS 






OPCODE 




COMPARED 


BITS 




MNEMONIC 


466789 


MEANING 


TOO 


AFFECTED 


DESCRIPTION 


AR 


110001 


Add Real 


Yes 


0^ 


FPAC + (SA,SA + 2) -^FPAC 


SR 


110011 


Subtract Real 


Yes 


0^ 


FPAC - (SA,SA + 2) —FPAC 


MR 


110100 


Multiply Real 


Yes 


0-4 


(SA,SA + 2)* FPAC -FPAC 


DR 


110101 


DivkJeReal 


Yes 


0-4 


FPAC / (SA,SA + 2) —FPAC 


LR 


110110 


Load Real 


Yes 


0-2 


(SA,SA + 2) — FPAC 


STR 


110111 


Store Real 


Yes 


0-2 


FPAC— (SA,SA-i-2) 


CIR* 


110010 


Convert Int to Real 


Yes 


0-4 


Real Representation of (SA) — 
FPAC 



*CIR Is actually a single operand furxitfon; however, its operand is pointed to by SA, not necessarily the FPAC. 
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B.4.2 Single-Operand Floating Point Instructions 

General 
Format: 






1 


2 


3 


4 


5 


6 


7 


8 


9 


10 


11 


12 


13 14 


15 














1 


1 























OPCD 








OPCODE 




RESULT 


STATUS 






11 




COMPARED 


BITS 




MNEMONIC 


34 


MEANING 


TOO 


AFFECTED 


DESCRIPTION 


CRI 


00 


Convert Real to Int 


Yes 


0^ 


Int Representation of FPAC —■ FPAC 


NEGR 


01 


Negate Real 


Yes 


0-2 


- FPAC -♦FPAC 


CRE 


10 


Convert Real to Ext Int 


Yes 


0^ 


Ext Int Representation of FPAC — 
FPAC 


CER 


11 


Convert Ext Int to Real 


Yes 


0-4 


. Real Representation of FPAC -*■ 
FPAC 



B.4.3 Dual-Oparand Hoating Point Instructions with IMultiple Addressing IModes for the Source and Destination 
Operands 

General 
Format: 






1 


2 


3 


4 5 


6 


7 8 


9 


10 11 


12 


13 14 


15 

















1 


1 








OPCODE 














1 " 




D 




1 Ts 




S 


1 



The addressing mode for the operands is determined by the Tx fields (X being either D or S). 



Tx 


X 


ADDRESSING MODE 


NOTES 



1 
2 
2 
3 


0,1 15 

0,1 15 



1,2 15 

1,2 15 


Workspace register 

Workspace register indirect 

SymboKc 

Indexed 

Workspace register incfirect autoincrement 


1 
1,2 



NOTES: 1. WoricspaceragtetsrOmavnotbeuaed. 

2. The woriupacaregiBtar is incramanted by 4 unlaaBX-»D ami opcode -♦OOIO (MM) in which caaetha workspace regist^ 





OPCODE 




RESULT 


STATUS 






1111 




COMPARED 


BITS 




MNEMONIC 


2346 


MEANING 


TOO 


AFFECTED 


DESCRIPTION 


CR 


0001 


Compare Reals 


No 


0^ 


(SA,SA + 2) - (DA,DA + 2) Set Sta- 
tus 


MM 


0010 


Multiply Multiple 


Yes 


0^ 


«SA,SA + 2) • (DA,DA + 2) -* 
(DA,DA + 2,DA + 4,DA + 6) (Un- 
signed, Integer) 



110 



B .4.4 Status Bit Summary for Floating Point I nstructions 

The following table summarizes the conditions that set the status register bits during execution of floating point instruc- 
tions. 

TABLE B.3 - ADDITIONS FOR THE 99 110 VERSION 



BIT 


NAME 


INSTRUCTION 


CONDITION TO SET BIT T0 1 
(OTHERWISE SET TOO) 


STO 


Logically 
greater than 


AR,SR,MR, 

DR.LR,STR, 

NEGR,CIR, 

CER,CRI, 

CRE.CR 


If result is not 


MM 


Cleared unconditionally 


ST1 


Arithmetic 
greater than 


AR.SR.MR 

DR,LR,STR 

NEGR,CIR, 

CER,CRI, 

CRE 


lfMSBofresult = 0, 
and result is not 


CR 


lf(SA)>(DA) 


MM 


Cleared unconditionally 


ST2 


Equal/TB 
Indicator 


AR,SR,MR 

DR,LR,STR, 

NEGR.CIR, 

CER,CRI, 

CRE.MM 


If result = 


CR 


lf{SA) = (DA) 


ST3 


Carry out 


LR.STR,NEGR 


Unaffected 


AR,SR,MR,DR 


If exponential overflow occurs 


MM,CR 


Cleared unconditionally 


CIR.CER 


Set unconditionally 


CRI,CRE 


If real source cannot be represented if the format selec- 
ted 


ST4 


Arithmetic 
Fault 


LR.STR.NEGR 


Unaffected 


AR,SR,MR,DR 


If exponential over/underflow occurs 


MM.CR, 
CIR,CER 


Cleared unconditionally 


CRi.CRE 


If real source cannot be represented if the format selec- 
ted 


ST5- 
ST15 




All Floating 

Point 

Instructions 


Unaffected 
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TI Sales Offices 



ALABAMA: HMMIIe. 500 Wynn Drive. Suite 514. Huntsville. 
AL 35805. (205) 837-7530. 

ARSZOSA: Pfeswsis, P.O. Box 35160. 8102 N 23rd Ave.. Suite 
B. Phoenix. AZ 85021. (602) 995-1007 

CAUFORMM: El SaoMdo. 831 S Douglas St . El Seoundo. 
CA 90245. (213) 9^2571: Mm, 17891 Cartwright Rd.. 
Iivine. CA 92714. (714) 680-1200: Satfainciito, WO Point 
West Way. Suite 171. Sacramento. CA 95815. (916) 929-1521; 
Sm Oieao, 4333 View Ridge Ave . Suite B . San Diego. CA 
92123. (714) 278-9600: Swrta Clifa, 5353 Betsy Ross Dr. 
Santa Clara. CA 95054. (408) 980-9000: WoadlMrt Hills, 
21220 Erwin St.. Woodland Hills. CA 91367. (213) 704-7759. 

COLORADO: Oemw, 9725 E. Hampden St . Suite 301. Den- 
ver CO 80231. (303) 695-^00 

COfWECnCUT: WalUnglord. 9 Barnes Industrial Park Rd 
Barnes Industrial Park. Wallingford. CT 06492. (203) 
269-0074. 

FLORIOA: ClesnMter, 2280 US Hwy 19 N . Suite 232. 
Clearwater. FL 33515. (813) 796-1926: R. Laoderdale. 2765 
N W. 62nd St . Ft Uuderdale. FL 33309. (305) 973-8502: 
MiHlMd, 2601 Maitland Center Parkway. Maitland. FL 32751. 
(305) 646-9600 

GEORGIA: Allmta, 3300 Northeast Expy . Building 9. Atlanta. 
GA 30341. (404)452-4600 

ILUNOIS: ArliMtoii H«igMl, 515 W Algonquin. Arlington 
Heights. IL 60005. (312) 640-2934 

INDIANA: R. Wayie. 2020 Inwood Dr. Ft V\^yne. IN 46805. 
(219) 424-5174: Indiampolis. 2346 S Lynhurst. Suite J-400 
Indianapolis. IN 46241. (317) 248-8555 

IOWA: Cedar Rapids. 373 Collins Rd NE. Suite 200. Cedar 
Rapids. lA 52402. (319) 395-9550 



MARYLAND: BaMMn, 1 Rutherford PI.. 7133 Rutherford 
Rd.. Baltimore. MD 21207. (301) 944-8600. 

MASSACHUSETTS: ^&ssi, 504 Tstten Pond Rd . W^lthan-, 
MA 02154. (617) 890-7400. 

MICHIGAN: Fanaiaals* MNs, 33737 W. 12 Mile Rd . Farm- 
ington Hills. Ml 48(ri8. (313) 553-1500. 

MamESOTA: Edim. 7625 Parklawn. Edina. MN 55435. (612) 
830-1600. 

MISSOUfll: Kanas C% 8080 VKird Pkwy . Kansas City. MO 
64114. (816) 523-2500: St. Laois, 11861 vitestline Industrial 
Drive. St. Louis. MO 63141. (314) 569-7600. 

NEW JERSEY: Claik. 292 lerminal Ave West. Clark. NJ 
07066 (201) 574-9800. 

NEW MEXKO: Attaqaanw. 5907 Alice NSE. Suite £. Albu- 
querque. NM 87110. (505) 265-8491 

NEW YORK: East Swacase. 6700 OM Collamer Rd . East 
Syracuse. NY 13057. (315) 463-9291: Endicolt, 112 Nantlcoke 
Ave . PO Box 618. Endicotl. NY 13760. (607) 754-3900: 
MeMllt, 1 Huntington Quadrangle. Suite 3D0. PO Box 
2936. Melville. NY 11747. (516) 454-6600: Paa«MHWMi«. 
201 South Ave.. Poughkeepsie. NY 12601. (914) 473-2900: 
Rockestti. 1210 Jefferson Rd . Rochester. NY 14623. (716) 
424-5400 

NORTH CAROLINA: Ckariotta. 8 Woodlawn Green. Woodlawn 
Rd . Charlotte. NC 28210. (704) 527-0930: RAUIGH. 3000 
Highwoods Blvd . Suite 118. Raleigh. NC 27625. (919) 
876-2725 

OHIO: BaadiMoad. 23408 Commerce Park Rd . Beachwood. 
OH 44122. (216) 464-6100. Oavtan. Kingsley BIdg . 4124 
Linden Ave . Dayton. OH 45432. (513) 258-3877 



OKLAHOMA: Dilsa. 3105 E. Skelly Dr. Suite 110. Tulsa. OK 
74105. (918) 749-9547. 

OREGON: Baswrtss. 6700 SW 105th St., Suite 110. Beaver- 
ton. OR 97005. (503) 643-6758. 

PENNSYUANIA: R. WasMngtOR. 575 Virginia Dr.. Ft Wash- 
ington. PA 19034. (215) 643-6450: Coraopolis, PA 15108. 420 
Rouser Rd.. 3 Airport (Jffice PK. (412) 771-8550 

TENNESSEE: Jdmson City. PO. Drawer 1255. Erwin Hwy.. 
Johnson City. TN 37601. (615) 461-2191. 

TEXAS: AusttR, 12501 Research Blvd.. RD Box 2909. Austin. 
TX 78723. (512) 250-7655: Dallas. PO. Box 1087, Richard- 
son. TX 75080: Haasten, 9100 Southwest Fnivy. . Suite 237. 
Houston. TX 77036. (713) 778-6592: San Antoaio. 1000 
Central Park South. San Antonio. TX 78232. (512) 496-1779. 

UTAH: Salt Laka City. 3672 West 2100 South. Salt Lake City 
UT 84120. (801) 973-6310. 

VIRGINU: Fairfax. 3001 Prosperity. Fairfax, VA 22031, (703) 
849-1400: MidlolNian. 13711 Sutter's Mill Circle. Midlothian, 
VA 23113. (804) 744-1007 

WISCONSIN: Braokfiald, 205 Bishops Way. Suite 214, Brook- 
field. Wl 53005, (414) 784-3040. 

WASHINGTON: RedmORd. 2723 152nd Ave.. NE. BIdg 6. 
Redmond. WA 98052. (206) 881-3080. 

CANADA: (MaiM, 436 McClaren St.. Ottawa. Canada. 
K2P0M8. (613) 233-1177: Rieimiond Hill. 280 Centre St E . 
Richmond Hill L4C1B1. Ontario. Canada.]416) 684-9181: St. 
Laareirt. Ville St. Laurent Quebec. 9460 Trans Canada Hwy.. 
St Laurent. Ouet)ec. Canada H4S1R7. (514) 334-3635. P 



TI Distributors 



ALABAMA: Hall-Mark (2051 837-8700 

ARIZONA: Ptieenix. Kierulff (602) 243-4101: Marshall (6021 
968-6181: R V Weatherlord (602) 272-7144: Wyle (602) 
249-2232: Dicsaa. Kierulff (602) 624-9986 

CAUFORNIA: Los Aageles/Oraaga Couaty. Arrow (213) 
701-7500. (714) 85ll961: JACO (714) 540-5600. (213) 
998-2200: Kierulff (213) 725-0235. (714) 731-5711: Marshall 
(213) 999-5001. (213) 68(5-0141. (714) 556-6400: R.V 
weathetford (714) 634-9600. (213) 849-3451. (714) 623-1261: 
Wyle (213) 322-8100. (7141 641-1611: San Die«a. Arrow (714) 
565-4800. Kierulff (714) 278-2112: Marshall (714) 578-9600: 
R V Weatherford (714) 695-1700: Wyle (714) 565-9171: San 
Francisco Bay Area. Arrow (408) 745-6600: Kierulff (415) 
968-6292: Marshall (408) 732-1100: Time (408) 734-9888: 
United Comonents (408) 496-6900: Wyle (408) 727-2500: 
Santa Barkara. R.V Weatherford (805)465-8551 

COLORADO: Arrow 1303) 758-2100: Kierulff (303) 371-6500: 
R.V Weatherford (303) 428-6900: Wyle (303) 457-9953 

CONNECTICUT: Arrow (203) 265-7741: Dipk)mat (203) 
797-9674: Kierulff (203) 265-1115: Marshall (203) 265-3822: 
Milgray (203) 795-0714 

FLORIDA: R. Laaderdale. Arrow (305) 973-8502: Diplomat 
(305) 971-7160: Hail-Mark (305) 971-9280: Kierulff (305) 
652-6950: Orlando. Arrow (305) 725-1480: Diptomat (3051 
725-4520: Hall-Mark (305) 855-4020: Milgray (305) 
647-5747: lampa. Diplomat (812) 443-4514: Kierulff 
(813)576-1966. 

GEORGIA: Arrow (404) 449-8252 Hall-Mark (404) 447-8000: 
Kierulff (404) 447-5252: Marshall (404) 923-5750. 

ILUNOIS: Arrow (312) 397-3440: Diplomat (312) 595-1000: 
Hall-Mark (312) 860-3800: Kierulff (312) 640-0200: Newark 
(312) 638-4411. 

INDIANA: bidianaiiolis. Arrow (317) 243-9353: Graham (317) 
634-8202: R. Wayna, Graham (219) 423-3422. 

IOWA: Arrow (319) 395-7230. 



KANSAS: Kansas City. Component Specialties (913) 
492-3555: Hall-Mark (9131 88i3-4747: WicMla. LCOMP (316) 
265-9507 

MARYLAND: Arrow (301) 247-5200: Diplomat (301) 995-1226: 
Hall-Mark (301) 796-9300: Kierulff (301) 247-5020: Milgray 
(301) 468-6400 

MASSACHUSETTS: Arrow (617) 933-8130: Diptomat (617) 
429-4120: Kierulff (617) 667-8331: Marshall (617) 272-8200: 
Time (617) 935-8080 

MICHIGAN: Oetrait. Arrow (313) 971-8200: Newark (313) 967- 
0600: Grand Rapids. Newark (616) 243-0912 

MINNESOTA: Arrow (612) 830-1800: Diplomat (612) 788-8601: 
Hall-Mark (612) 854-3223: Kierulff (612) 941-7500 

MISSOURI: Kaasas City; LCOMP (816) 221-2400: St. Laois. 
Arrow (314) 567-6888: Hall-Mark (314) 291-5350: Kierulff 

(314) 739-0855 

NEW HAMPSHIRE: Arrow (603) 668-6968 

NEW JERSEY: Arrow (201) 575-5300: Diplomat (201) 
785-1830: JACO (201) 778-4722: Kierulff (201) 575-6750: 
Marshall (201) 340-1900. 

NEW MEXICO: Arrow (505) 243-4566: International 
Electronics (505) 345-8127 

NEW YORK: Lang Islaad. Arrow (516) 231-1000: Diplomat 
(516) 454-6400: JACO (516) 273-5500: Marshall (516) 
273-2424: Milgray (516) 546-5600. (800) 645-3986: 
Rodiaslar. Arrow (716) 275-0300: Marshall (716) 235-7620: 
Rochester Radio Supply (716) 454-7800: Syracasa. Arrow 

(315) 652-1000: Diplomat (315) 652-5000: Marshall (607) 
754-1570 

NORTH CAROLRM: Arrow (919) 876-3132. (919) 725-8711: 
Hall-Mark (919) 872-0712: Kierulff (919) 852-6261 

OHIO: CiaciaMH. Graham (513) 772-1661: Clayalaad, Arrow 
(?I6) 248-3990: Hall-Mark (216) 473-2907: Kierulff (216) 
587-6558: Cotambas. Hall-Mark (614) 846-1882: Darian. 
Arrow (513) 435-5563: ESCO 1513) 226-1133: Marshall (513) 
236-8088 



OKLAHOMA: Component Specialties (918) 664-2820: Hall- 
Mark (918) 665-3200: Kierulff (918) 252-7537 

OREGON: Kierulff (503) 641-9150: Wyle (503) 640-6000. 
PEMBYLVAWA: Arrow (412) 856-7000: Arrow (609) 
235-1900: General Radio (609) 964-8560: Hall-Mark (609) 
424-0880: Milgray (609) 983-5010. 

TEXAS: AasUn, Arrow (512) 835-4180: Component Specialties 
(512) 837-8922: Hall-Mark (512) 258-8848: Kierulff (512) 
835-2090: Dallas, Arrow (214) 386-7500: Component 
Specialties (214) 357-6511: Hall-Mark (214) 341-1147: 
International Electronics (214) 233-9323: Kierulff (214) 
343-2400: El Paso. International Electronics (915) 778-9761: 
Hoaston, Arrow (713) 491-4100: Component Specialties (713) 
771-7237: Hall-Mark (713) 781-6100: Harrison Equipment 
(713) 879-2600: Kierulff (713) 530-7030. 

UTAH: Diptomat (801) 486-4134: Kierulff (801) 973-6913: Wyle 
(801) 974-9953 

VIRGINIA: Arrow (04) 282-0413. 

WASHHIGTON: Arrow (206) 643-4800: Kierulff (206) 

575-4420: United Components (206) 643-7444: Wyle (206) 

453-8300. 

WISCONSIN: Arrow (414) 764-6600: Hall-Mark (414) 

761-3000: Kierulff (414) 784-8160. 

CANADA: Calgary. Future (403) 259-6408: V^rah (403) 
230-1235: DowRSviaw. CESCO (416) 661-0220: Hamiitan, 
V^rah (416) 561-9311: Moatraal. CESCO (514) 735-5511: 
Future (514) 694-7710: Ottam. CESCO (613) 226-6905: 
Future (613) 820-8313: Oaabac City, CESCO (418) 687-4231: 
Ibranto, Future (416) 663-5563: Vaacoaver. Future (604) 
438-5545: Varah (604) 873-3211: Winnipag. Varah (204) 
633-6190. AJ 



Printed in U.S.A. 
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Texas 
Instruments 



Tl W^ridwiae sales utnces 



ALABAMA: HwilwUle, 500 Wynn Drive. Suite 514. Huntsville 
AL 35805. (205) 837-7530 

ARIZONA: Pkomix. PO Box 35160. 8102 N 23rd Ave Suite 
B. Pt)0«nix. AZ 85021. (602) 995-1007 

CAUFORNM: El SMWidD. 831 S. Douglas St . El Seaundo 
CA 90245. (213) 973-2571; InriM, 17KI1 Cartwrighl fid . 
Irvine. CA 92714. (714) 660-1200: Sacnmmto, 1900 Point 
West Way. Suite 171. Sacramento. CA 95815. (916) 929-1521 
Sm DitM, 4333 View Ridge Ave. . Suite B . San Diego. CA 
92123. (714) 278-9600: SaMi dm. 5353 Betsy Ross Dr 
Santa Clara. CA 95054. (408) 980-9000: Mwdlaad Hills. 
21220 Erwin St.. Woodland HiHs. CA 91367. (213) 704-7759 

COLOMOO: Darner. 9725 E Hampden St . Suite 301 Den- 
ver. CO «)231. (303) 695-2800 

CONNECTKUT: WalHi^rtwd. 9 Barnes Industrial Park Rd 
Barnes Industrial Park^A/ltallingtord. CT 06492 (203) 
269^)074 

FLOmiM: dawwMw. 2280 US Hwy 19 N . Suite 232 
Clearwater. FL 33515. (813) 796-1926: Ft. LandenMe. 2765 
N W. 62nd St.. Ft Uuderdale. FL 33309. (305) 973-8502: 
IMtai<, 2601 Maitland Center Parkway Maitland. FL 32751 
(305) 646-9600 

GEOAGIA: AUMta. 3300 Nortlieast Expy Building 9 Atlanta 
GA 30341. (404) 452-4600 

N.UNOIS: AittMtMi Ht^m. 515 W Algonquin Arlington 
Heights. IL 60005. (312) 640-2934 

HNHAMA: Fl. Wma. 2020 Inwood Dr . Ft Wayne IN 46805 
(219) 424-5174: MlanMOHt. 2346 S Lynhurst Suite J-400 



Indianapolis. IN 46241. (317) 248-8555 

nWA: Mm RapM. 373 Collins Rd NE Suite 200 Cedar 
Rapids. lA 52m. (319) 395-9550 



MARYLANO: Battimor*. 1 Rutherlord PI . 7133 Rutherford 
Rd Baltimore MD 21207 (301) 944-8600 

MASSACHUSrnS: WaWiain. 504 Totten Pond Rd Waltham 
MA 02154. (617) 890-7400 

MICHIGAN: Farnilaetofl Hills. 33737 W 12 Mile Rd farm 
mgton Hills. Ml 48018 1313) 553-1500 

MINIKSOTA: Edma. 7625 Parklawn Edma MN 55435 i6i2i 
830-1600 

MISSOURI: Kaasas City, 8(»0 Ward Pkwy Kansas City MO 
64114. (816) 523-2500: St. LeuK. 11861 Westline Industrial 
Drive. St Louis MO 63141 (3141 569-7600 

NEW .KRSEY: Clafk. 292 Terminal Ave West Clark NJ 
07066. (201) 574-9800 

NEW MEXICO: Altaquareue. 5907 Alice NSE SuHe E Albu 
querque NM 87110 (505) 265-8491 

NEW YORK: East Syracuse. 6700 Old Collamer Rd East 
Syracuse. NY 13057. (315) 463-9291: EmHeon. 112 Nanticoke 
Ave.. PO Box 618. Endicott. NY 13760. (607) 754-3900 
MeMlle. 1 Huntington Quadrangle. Suite 3C10. PO Box 
2936. Melville. NY 11747. (516) 454-6600: Poughkaaom. 
201 South Ave . Poughkeepsie. NY 12601 (914) 473-2900 
Reckesler. 1210 Jefferson Rd . Rochester. NY 14623 (716) 
424-5400 

NORTH CAROLINA: Ckarlotla. 8 Woodlawn Green. Woodlawn 
Rd . Charlotte. NC 28210. (704) 527-(»30: RALEIGH. 3(ffl0 
Highwoods Blvd Suite 118 Raleigh, NC 27625 1919) 
876-2725 

OHIO: Beacbwood, 23408 Commerce Park Rd Beachwood 
OH 44122. (216) 464-6100. Dayton. Kingsley Bidg 4124 
Linden Ave Dayton OH 45432 (5131 258-3877 



OKLAHOMA: Tuisa. 310S E Skelly Di Suite 110 Tuisa OK - 
74105 (9181 749-9547 

OREGON: Beaverton. 6700 SW lOSth St Suite 110 Beavei- 
ton. OR 97005 (503) 643-6758 

PENNSYLVANIA: Ft. WasHington, 575 Virginia Or Ft Wash- 
ington. PA 19034 (215) 643-6450: Coraopolis. PA 15108 420 
Rouser Rd 3 Airport Office PK (412) 771-8550 

TENNESSEE: Johnson City. PO Drawer 1255. Erwin Hwy 
Johnson City TN 37601. (615) 461-2191 

TEXAS: AasUn. 12501 Research Blvd . PO Box 2909. Austin 
TX 78723. (512) 250-7655: Dallas. PO Box 1087. Richard- 
son TX 75080: Houston. 9100 Southvwst Frwy.. Suite 237 
Houston. TX 77036. (713) 778-6592: San Antonio. 1000 
Central Park South, San Antonio. TX 78232, (512) 496-1779 

UTAH: SaH Lalte City. 3672 West 2100 South Salt Lake City 
UT 84120, (801) 973-6310 

VIRGINIA: Fairfax. 3001 Prosperity Fairfax, VA 22031. (7031 
849-1400: MMMhian. 13711 Sutlers Mill Circle Midlothian 
VA 23113, (804) 744-1007 

WISCONSIN: BrookticM. 205 Bishops Way Suite 214 Brook- 
field. Wl 53005. (414) 784-3040 

WASHINGTON: Redmond. 2723 152nd Ave N E BIdg 6 
Redmond WA 98052. (206) 881-3080 

CANADA: Ottawa. 436 McClaren St . Ottawa. Canada. 
K2P0M8. (613) 233-1177: Rickmrnid Hill. 280 Centre St E 
Richmond Hill L4C1B1. Ontario. Canada. ]416) 884-9181: St. 
Laurent. Ville St Laurent Quebec. 9460 Trans Canada Hwy 
St Laurent Quebec Canada H4S1R7 (514) 334-3635 P 



AiW£N1IM. Texas Instruments Argentina S A I C F 
Esmeralda 130, 15lh Floor 1035 Buenos Aires Argentina 
394-2963 

AUSTRAUA (a NEW ZEAUUH)). Texas Instruments Australia 
Ltd : Unit 1A. 9 Bylietd St . North Ryde (Sydneyl New South 
Wiles. Australia 2113. 02 • 887-1122: 5th Floor, 418 St Kilda 
Road. kMbourne. Viaona. Austraba 3004 03 - 267-4677 

AUSTRIA, Texas Instruments Ges m b H Industnestrabe 
B 16. A-2345 Brunn Getxrge. 2236-846210 

BH.BHM. Texas Instruments N V Belgium S A Mercure 
Centre. Rakelstraal 100. Rue de la Fusee 1130 Brussels 
Belgium. 02 720 80 00 

BRAZH. Texas Instrument Electronicos do Brasil Ltda Av 
Faria Luna. 2003. 20 Andar — Pinheiros Cep-01451 Sao 
Paulo. Brazil. 815-6166 

DENMARK. Texas Instruments A S, Maneiundvei 46E 
DK-2730 Herlev. Denmark, 2 - 91 74 00 

FMLAHO. Texas Instruments Finland OY PL 56 00510 
Helsinki 51. Finland. (90) 7013133 

FRAIKE. Texas Instruments France: Headquarters and Prod 
Plant. BP 05. 06270 Villeneuve-Loubet. (93) 20-01-01; Pans 
Office. BP 67 8-10 Avenue Morane-Saulnier. 78141 Vellzy- 
Vlllacoublay. (3) 946-97-12: Lyon Sales Office. L Oree 
DEcully. Batiment B. Chemin de la Forestiere. 69130 Ecully 
(7) 833-04-40; Strasbourg Sales Office. Le Sebastopol 3. Ouai 
Kleber. 67055 Strasbourg Cedex. (88) 22-12-66; Rennes. 
23-25 Rue du Puils Mauger. 35100 Rennes. (99) 79-54-81; 
Toulouse Sales Office. Le Peripole — 2. Chemin du Pigeonnier 
de la Cepiefe. 31100 Toulouse. (61) 44-18-19; Marseille Sales 
Office. Noilly Paradis — 146. Rue Paradis. 13006 Marseille, 
(91) 37-25-30 



GERMANY, Texas Instruments Oeutschland GmbH Haggerty- 
strasse 1 D-8050 Freising 08161-801; Kurluerstendamm 
195 196. D-1000 Berlin 15 030-8827365; III. Hagen 43 Kib 
belstrasse. 0-4300 Essen. 0201-24250; Frankfurter Aliee 6-8 
0-6236 Eschborn 1, 06196-43074; Hamburger Strasse 11 
D-2000 Hamburg 76 040-2201154, Kiichhorsterstrasse 2 
D-3000 Hannover 51 0511-648021; Arabellastrasse 15 
0-8000 Muenchen 81. 0^-92341; Maybachstrasse 11 0-7302 
Ostfildem 2 Netlmgen. 0711-34030 

HONG KONG ( + PEOnJS REPUBLIC OF CHINA). Texas 
Instruments Asia Ltd 8th Floor World Shipping Ctr Harbour 
City 7 Canton Rd . Kowloon Hong Kong 3 ■ 722-1223 

IRELAND. Texas Instruments (Ireland) Limited 25 St 
Stephens Green Dublin 2. Eire 01 609222 

ITALY, liexas Instruments Semicondutton Italia Spa Viale 
Delle Scienze. 1 02015 Cittaducale (Rieti). Italy. 0746 694 i 
Via Salana KM 24 (Palaso Cosma), Monterotondo Scalo 
(Rome). Italy 06 9004395; Viale Europa, 38-44 20093 
Cologno Monzese (Milano). 02 2532541; Corso Svizzera 185 
10100 Torino, Itahr. Oil 774545: Via J Barozzi. 6. 45100 
Bologna. Italy. 051 355851; Via Nazareth, 7 35100 Padova 
Italy 049 850386 

JAPAN. Texas Instruments Asia Ltd ; 4F Aoyama Fu|i BIdg 
4-12. Kila Aoyama 3-Chome. Minato-ku. Tokyo. Japan ^0^. 
03-498-2111: Osaka Branch. 5F Nissho Iwai BIdg . 30 Im- 
abashi 3-Chome. Higashi-ku. Osaka. Japan 541. 06-204-1881: 
Nagoya Branch, 7F Oaini Toyota West BIdg . 10-27. Meieki 
4-(:home. Nakamura-ku. Nagoya. Japan 450. 052-583-8691 

KOREA. Texas Instruments Supply Co.; Room 201. Kwang- 
poong BIdg.. 24-1. Hwayand-ljong. Sungdong-ku. 133 Seoul 
Korea. 02 • 464-6274 5. 

MEXICO. Texas Instruments de Mexico S A Poniente 116 
No 489. Colonia Vaileio. Mexico. OF 02300. 567-9200 

MIDDLE EMT. Texas Instruments; No. 13. 1st Floor Mannai 
BIdg, Diplomatic Area. Manama, PO Box 26335. Bahrain. 
Arabian (5ulf. 973 - 27 46 81 



NETHERLANDS. Texas Instruments Holland 8 V Semiconduc- 
tor Division Laan Van de Helende Meesters 421A 1186 AL 
Amstelveen, Nederland, 1020) 473391 

NORWAY. Texas Instruments Norway A S Kr Augustsgt 13. 
Oslol. Norway (2)20 60 40 

PHILIPPINES. Texas Instruments Asia Ltd 14th Floor. Ba- 
Lepanto BIdg , 8747 Paseo de Roxas. Makati, Metro Manila, 
Philippines, 882465 

PORTUGAL, ■fexas Instruments Equipamento Electronico 
(Portugal). Lda ; Rua Eng Frederico Ulnch, 2650 Moreira Da 
Maia. 4470 Maia. Portugal, 2-9481003 

SCOTLAND. Texas Instruments Limited 126-128 George 
Street. Edinburgh, Sc(«land. EH1 2AN, 031 226 2691 

SWGMniRE ( + INDU. HHMNESU. MALAYSIA. THAaAW)), 

teas Instruments Asia Ltd ; P Box 138, Unit #02-08. 
Block 6. Kolam Aver Industrial Est . Lorong Bakar Batu. 
Singapore 1344 Republic of Singapore. 747-2255 

SPAIN, Texas Instruments Espana. S A C Jose Lazaro Gal- 
diano No 6. Madrid 16. 1 458 14,58 

SWEDEN. Texas Instruments International Trade Corporation 
(Sverigefilialen) Box 39103. 10054 Stockholm. Sweden, 08 - 
2354M) 

TAIWAN, Texas Instruments Supply Co : 10th Floor. Fu-Shing 
BIdg,. 71 Sung-Kiang Road. Taipei. Taiwan. Republic of China. 
02 + 521-9321 

UNTTED KINGDOM, Texas Instruments Limited; Manton Lane, 
Bedford. MK41 7PA. England. 0234 67466; 186 High Street. 

Slough. SL1 1LD, England. 0753 35545; St. James House, 
Wellington Road North Stockport. SK4 2RT. England, 061 
442 8448. AK 
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